当前位置: 首页 > news >正文

展示型网站建设模板德州做网站

展示型网站建设模板,德州做网站,网站整站优化推广方案,网站质作背景 验证码这个功能是十分常见的#xff0c;各大系统的登录页面都会有。今天介绍一下最为普通的验证码。无论最终给到前端的是图片格式的验证码还是base64格式的验证码#xff0c;其实都离不开这样的一步操作#xff0c;都要先在后台生成一个图片。就个人经验来说#xff… 背景 验证码这个功能是十分常见的各大系统的登录页面都会有。今天介绍一下最为普通的验证码。无论最终给到前端的是图片格式的验证码还是base64格式的验证码其实都离不开这样的一步操作都要先在后台生成一个图片。就个人经验来说早期的.NET Core想在Linux/Docker下面搞图片这些还是相对麻烦一些的首先是组件这一块其次是依赖这一块。不过现在方便多了。下面就基于ImageSharp这个组件来实践一下。准备工作 安装相应的nuget包ItemGroupPackageReference IncludeSixLabors.ImageSharp Version1.0.0-beta0007 /PackageReference IncludeSixLabors.Fonts Version1.0.0-beta0009 /PackageReference IncludeSixLabors.ImageSharp.Drawing Version1.0.0-beta0007 / /ItemGroup 需要注意的是ImageSharp目前还不是正式版。准备一下字体文件示例用的是comic.ttf这个只有240kb算是比较小的了。这里选一个小一点的字体是因为不想让打包好的镜像太大如果各位大佬有更小体积的字体可以告诉我一下哈。编码实现 首先是生成随机数应该不用说太多如果先生成完成不一样的数字或字母自由控制就好。private static string GenCode(int num) {var code  string.Empty;var r  new Random();for (int i  0; i  num; i){code  Chars[r.Next(Chars.Length)].ToString();}return code; } 然后就是生成的核心代码了。private static readonly Color[] Colors  { Color.Black, Color.Red, ... }; private static readonly char[] Chars  { 0, .... }; private static readonly int Width  90; private static readonly int Height  35;public static (string code, byte[] bytes) GenVCode(int num) {var code  GenCode(num);var r  new Random();using var image  new ImageRgba32(Width, Height);// 字体var font  SystemFonts.CreateFont(SystemFonts.Families.First().Name, 25, FontStyle.Bold);image.Mutate(ctx {// 白底背景ctx.Fill(Color.White);// 画验证码for (int i  0; i  code.Length; i){ctx.DrawText(code[i].ToString(), font, Colors[r.Next(Colors.Length)], new PointF(20 * i  10, r.Next(2, 12)));}// 画干扰线for (int i  0; i  10; i){var pen  new Pen(Colors[r.Next(Colors.Length)], 1);var p1  new PointF(r.Next(Width), r.Next(Height));var p2  new PointF(r.Next(Width), r.Next(Height));ctx.DrawLines(pen, p1, p2);}// 画噪点for (int i  0; i  80; i){var pen  new Pen(Colors[r.Next(Colors.Length)], 1);var p1  new PointF(r.Next(Width), r.Next(Height));var p2  new PointF(p1.X  1f, p1.Y  1f);ctx.DrawLines(pen, p1, p2);}});using var ms  new System.IO.MemoryStream();// gif 格式image.SaveAsGif(ms);return (code, ms.ToArray()); } 都是中规中矩的代码这里需要注意下面几个地方关于字体这里取的是当前系统的第一个如果系统一个字体都没有那肯定是抛异常的。正常的.net core的docker镜像是没有的所以这也是为什么我们在前面要准备字体的原因。Fill、DrawText、DrawLines这三个画图的方法大家看看说明就可以了对于生成格式老黄这里用的是Gif它支持BmpGifJpegPng还有Base64大家可以按需选择这里建议用Gif或Jpeg因为生成的图片会比较小2.5kb左右。最后就是调用了。[HttpGet] public IActionResult GetCode() {var (code, bytes)  VCodeHelper.GenVCode(4);// code handle logicSystem.Console.WriteLine(code);return File(bytes, image/gif); } Dockerfile 简单修改一下Dockerfile加一句复制字体的命令。FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base WORKDIR /app EXPOSE 80# 复制字体到 /usr/share/fonts 目录 COPY ./comic.ttf /usr/share/fonts/comic.ttfFROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build WORKDIR /src COPY . . RUN dotnet restore VCodeTest.sln WORKDIR /src/VCodeTest RUN dotnet build VCodeTest.csproj -c Release -o /app/buildFROM build AS publish RUN dotnet publish VCodeTest.csproj -c Release -o /app/publishFROM base AS final WORKDIR /app COPY --frompublish /app/publish . ENTRYPOINT [dotnet, VCodeTest.dll] 效果 生成镜像运行效果如下文中的示例代码可以在我的github找到:https://github.com/catcherwong-archive/2020/tree/master/05/VCodeTest小结 ImageSharp 这个组件用起来还是挺舒服的大家可以尝试尝试。
http://www.pierceye.com/news/715207/

相关文章:

  • wordpress导航网站模板下载wordpress 关闭搜索引擎
  • 网站架构的优化wordpress企业主题免费下载
  • 分类信息网站手机版自学编程从哪学起
  • 网站目录 index.html京伦科技网站做的怎么样
  • 学做简单网站视频教程济源建设网站
  • 一个网站开发成本网店推广方案范文
  • 为什么要做seo盐城网站优化
  • 网站策划方案ppt站长查询域名
  • 网站开发需要哪些流程wordpress 添加widget
  • 在线报名网站建设汉字logo设计生成器
  • 移动网站和桌面网站区别烟台网站设计制作公司电话
  • 遵义网站建设网站定制wordpress主题多少钱
  • 外贸网站如何做推广是什么意思长沙制作公园仿竹护栏多少钱一米
  • seo网站有优化培训吗小程序商城开发华网天下优秀
  • 无锡品牌网站建设介绍网络营销是不是网络推广
  • 旅游网站建设论文题目商用图片的网站
  • 做网页专题 应该关注哪些网站网页版梦幻西游吸血鬼怎么过
  • gwt 网站开发深圳公司形象墙制作
  • 自己做的网站别人打不开大连网站建设方案维护
  • 卖高仿名牌手表网站两学一做网站飘窗
  • 企业网站备案资料样本购卡网页怎么制作
  • 什么网站能免费做简历ui设计师是什么意思
  • 天津网站推广公司哪家好深圳公司注册流程及资料
  • 家装网站建设哪家好点赣州市南康建设局网站
  • 北京建设网站制作我国外贸网站的建设
  • 自己做网站如何赚钱excel做网站
  • 芯片商城网站建设wordpress批量替换图片路径
  • 网站添加手机站软件 项目管理系统
  • 大理装饰公司做网站网站建设费用:做个网站要多少钱?
  • 简约的网站设计界面百度收录网站左侧图片