只能说,部署.net core 运行时的文章基本上说的都是安装sdk版本的,所以研究了2天,百度了大量的文章,终于安装好了。步骤如下:

1、安装nginx环境

2、安装必须的东西,具体我也不知道,命令如下:
yum install libunwind libicu

3、下载runtime,要下载2个,一个是netcore runtime,一个是dotnet core runtime,下载下来后解压并安装:

sudo mkdir -p /opt/dotnet && sudo tar zxf dotnet.tar.gz -C /opt/dotnet 
sudo ln -s /opt/dotnet/dotnet /usr/local/bin
sudo tar zxf aspnetcore.tar.gz /opt/dotnet

第一行是建立文件夹并解压缩
第二行是在/usr/local/bin创建一个dotnet的链接,连接到/opt/dotnet/dotnet上,这样子输入 dotnet命令就可以调用到命令了
第三行是将aspnet core runtime解压到netcore runtime目录下

到这里runtime环境算是搭好了,接下来就是创建一个网站,具体可以使用类似宝塔之类(安装完系统就先装个宝塔类的软件,可以快速搭建linux环境和管理网站)的软件来创建。

将visual studio的.net core项目发布,一种是独立部署,一种是依赖框架部署。

两种部署的简单区别如下(个人理解,不保证正确):

1、依赖框架部署,最精简的,相当于只发布了网站程序而已,能不能运行就看平台上支不支持你需要的运行环境了。

2、独立部署:比较臃肿,因为自带自需的运行时框架(但是前提应该是服务器已经安装了上面的基本环境),如果服务器的.net core runtime版本不是你的版本,那么程序还是可以运行的。

因为我安装的是.net core 3.0预览版,发现visual studio 2017只能支持目标框架2.0的所以无法正常发布,只能选择独立部署发布。发布到文件夹,将文件通过ftp上传到网站的根目录。

接下来就是运行网站程序了,输入命令:

dotnet netCoreStudy.dll

其中netCoreStudy我的项目名,发布出来后有一个netCoreStudy.dll

接着就能收到运行的提示了。

可能存在的错误:

1、Unable to bind to http://localhost:5000 on the IPv6 loopback interface.

这个问题好像是不能绑定5000端口,我给换了下端口,参考下图(往上转过来的):

先建立一个文档:port.json,或者你已经了自己配置的文件,增加下面这条内容:

"server.urls": "http://myname.com.cn:8000" 

例如我的port.json文件:

{
  "ConnectionStrings": {
    "DefaultConnection": "Server=(localdb)\\MSSQLLocalDB;Database=_CHANGE_ME;Trusted_Connection=True;MultipleActiveResultSets=true"
  },
  "server.urls": "http://myname.com.cn:8000" 
}

然后编辑program.cs文件,增加config的定义,然后引用config。

PS:内部的directory.getcurrentdirectory()我个人换成了appcontext.basedirectory

2、出现错误:

Error:
 An assembly specified in the application dependencies manifest (ZKEACMS.WebHost.deps.json) was not found:
 package: 'Microsoft.ApplicationInsights.AspNetCore', version: '2.1.1'
 path: 'lib/netstandard1.6/Microsoft.ApplicationInsights.AspNetCore.dll'
 This assembly was expected to be in the local runtime store as the application was published using the following target manifest files:
 aspnetcore-store-2.0.0-linux-x64.xml;aspnetcore-store-2.0.0-osx-x64.xml;aspnetcore-store-2.0.0-win7-x64.xml;aspnetcore-store-2.0.0-win7-x86.xml

这个是没有安装aspnet core runtime,参考前面的步骤。

var data = new { keyword1 = new { value =”参数1″ }, keyword2 = new { value = “参数2”} }; //定义模板参数内容
WxJsonResult jresult = Senparc.Weixin.WxOpen.AdvancedAPIs.Template.TemplateApi.SendTemplateMessage(
AppId, openId, templateId, data , formId, returnPage, “需要突出的内容”, “#fff00”);//小程序appid,信息接收人的OpenID,模板消息的ID,模板消息参数数据,formID(通过report-submit表单获取),返回页面路径(如:/pages/home/index),需要突出的内容,突出内容的字体颜色

            PdfSharp.Pdf.PdfDocument doc = new PdfDocument(); //实例化对象
            XImage img= XImage.FromFile(pngPath + "\\" + fileName + ".png"); //获取图片对象
            PdfPage page = doc.AddPage(); //增加1页
            page.Width = 212;
            page.Height = 269; //设置长宽            
            XGraphics g = XGraphics.FromPdfPage(page );
            g.DrawImage(img, 0, 0);

加个循环就可以一直添加新页并把图片写入pdf文件

        

        Bitmap bg = new Bitmap(500,500); //创建一个500x500px的画布
        bg.SetResolution(400, 400); //将画布设置为400x400分辨率
        Graphics g = Graphics.FromImage(bg); //新建画图对象
        g.Clear(Color.Transparent); //设置画图背景透明
        //将imgFile(通过FileDialog获取到的对象)画入画布并居中
        g.DrawImage(imgFile, (bg.Width - imgFile.Width) / 2, (bg.Height - imgFile.Height) / 2); //第二和三参数是置入图片在画布上的起始X和Y位置

 
        //设置文字
        System.Drawing.Font font = new System.Drawing.Font("思源黑体 CN", 12, FontStyle.Bold);  //设置字体
        SolidBrush brush = new SolidBrush(Color.White); //设置笔刷(写文字用)
        g.TextRenderingHint = System.Drawing.Text.TextRenderingHint.AntiAlias;//我选择这项,可以让写出来的文字没有黑边毛刺
        //写入文字
        g.DrawString(str, font, brush, xPosition, yPosition); //参数分别为写入的文字内容,字体,笔刷,x位置,y位置
        bg.Save(pngPath+"\\"+ no + ".png",ImageFormat.Png); //保存,参数分别为保存文件路径,图片格式
        brush.Dispose();
        font.Dispose();
        g.Dispose();
        img.Dispose();
        bg.Dispose();

说难也不难,希望对各位有用

需要做一个小程序上面的短信验证功能,正常流程如下:

客户端发起发送验证码请求(post/get)—–>服务器端收到请求——>生成验证码——>保存到Session——>返回给客户端——–>客户端输入验证码并发送给服务器端(post/get)——->服务端将收到的验证码与Session的验证码匹配——->返回匹配结果

这个流程一般是没问题的,然而代码写完就懵逼了,居然服务器端读不到Session,度娘告诉我:小程序的web请求都要经过腾讯的服务器,所以2次请求对方服务器来说都是新请求,所以后面的请求读不到前面的请求。

问题来了,怎么办呢?

我想的方案1:通过sessionID获取Session,然而,C#似乎没有根据SessionID获取Session的功能(当然了,太久没摸C#所以不知道怎么获取,有哪个兄嘚知道,记得告诉我下!),所以目前放弃这个方案。

方案2:Cache,悲催的我没研究Cache(毕竟算是新手,所以不熟悉Cache,暂时也不想研究太深入),所以放弃

方案3:数据库,目前用的是这么个方案,具体思路如下:

客户端发起请求—–>服务器端收到请求—–>生成验证码——->保存到数据库(uid,mobile,scence 3个条件用于后续)——>返回客户端——>客户端输入验证码发送给服务端——>服务器端收到验证码——->数据库取值(前面的3个条件来筛选,并且最好是order倒序,只取1条)并匹配——->返回匹配结果

 

public ActionResult SomeAction()
{
try
{
var sr = new StreamReader(Request.InputStream);
var stream = sr.ReadToEnd();
try
{
JArray arrary = JArray.Parse(stream);
foreach (JObject item in arrary)
{
string[] pars = item[“content”].ToString().Trim().Split(‘ ‘);
}
}
catch (Exception e)
{

}
}
catch (Exception e)
{

}
return new JsonResult()
{
Data = new { code = 0, msg = “接收成功” },
JsonRequestBehavior = JsonRequestBehavior.AllowGet
};
}

服务器的某个Action需要接收到一个json数组[{id:1,name:”abc”},{id:2,name:”hello”}],苦于不知道应该用什么参数接收,只能各种百度,最终写出了这个代码,勉强搞定这个功能了。

正常情况post过来的json数据,action都是可以自动解析的,比如给服务器post了个{id:1,name:”abc”},那么Action的声明可以这么写

public ActionResult SomeAction(int id,string name)

{

程序内可以直接调用id和name

}