.Net Core开发日志——Peachpie
.Net Core的生态圈随着开源社区的力量不断注入至其中,正在变得越来越强盛,并且不时得就出现些有意思的项目,比如Peachpie,它使得PHP的代码迁移到.Net Core项目变得可能。
从创建简单的入门程序开始可以更容易地体会其特性。
首先安装Peachpie的模板:
dotnet new -i Peachpie.Templates::*
接着创建项目:
dotnet new web -lang PHP -o helloPHP
然后切换目录至Server文件夹运行程序:
cd Server dotnet run
最后通过浏览器访问http://localhost:5004/:
Peachpie的运行机制很简单,将PHP文件编译成.Net平台的dll文件,这样就可以如同普通的.Net代码库一般被其它程序调用。
它包含三个部分:
- 编译器(peach.exe或者Peachpie.NET.Sdk),将PHP文件编译成.Net程序集
- 运行时(Peachpie.Runtime.dll),提供程序运行时所需的功能
- 代码库(Peachpie.Library.dll),包含PHP的函数,类及其它的实现
再回到开始的入门程序代码探究一番,可以发现关键点在于Website目录下的Website.msbuildproj文件中:
<Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <OutputType>Library</OutputType> <TargetFramework>netstandard2.0</TargetFramework> <AssemblyName>helloPHP</AssemblyName> </PropertyGroup> <ItemGroup> <Compile Include="**/*.php" /> </ItemGroup> <ItemGroup> <DotNetCliToolReference Include="Peachpie.Compiler.Tools" Version="0.9.0-*" /> <PackageReference Include="Peachpie.NET.Sdk" Version="0.9.0-*" PrivateAssets="Build" /> </ItemGroup> </Project>
在Peachpie.Compiler.Tools与Peachpie.NET.Sdk两者的作用下,包含index.php文件在内的所有PHP文件都最终会被编译成一个dll文件。
用使用这个dll文件也很简单,在Startup类的Configure方法里这样调用一下:
app.UsePhp(new PhpRequestOptions(scriptAssemblyName: "helloPHP"));
运行在ASP.Net中的PHP站点便诞生了。
Peachpie项目整体还在开发阶段,但不影响其已经能完成些惊人的工作,例如,其虽是构建在WordPress上,但已经被Peachpie编译成可以在ASP.NET中运行。仅凭以下的图你一定不会想到这个网站是PHP写成的:
在它的中可以看到关于此事的更详细信息。
如果你对PHP代码迁移到.Net平台这件事感兴趣的话,可以访问其在Github上的,若是能为它添砖加瓦的话,那是再好不过了。
上一篇: 亚洲“上链行动”计划在京启动
下一篇: 咋还男女不分了呢
推荐阅读
-
(14)ASP.NET Core 中的日志记录
-
详解.NET Core+Docker 开发微服务
-
简单谈谈.NET Core跨平台开发
-
Visual Studio 2017 ASP.NET Core开发
-
详解.net core webapi 前后端开发分离后的配置和部署
-
ASP.NET Core优雅的在开发环境保存机密(User Secrets)
-
.NET Core实战项目之CMS 第十章 设计篇-系统开发框架设计
-
Net Core平台灵活简单的日志记录框架NLog+SqlServer初体验
-
循序渐进学.Net Core Web Api开发系列【4】:前端访问WebApi
-
循序渐进学.Net Core Web Api开发系列【5】:文件上传