背景:  .net core 中默认已经取消可以直接访问图片,因为这样不安全. 导致我们上传的图片无法直接通过url访问.

解决方案: 

一: 通过修改项目配置,使可以直接通过url访问.(方法略,可以百度);

二: 图片都通过接口返回,接口里面读取项目的图片,然后返回流;

步骤:

1. 新建.net core 2.0 项目(过程略)

2. 通过nuget添加引用 System.Drawing.Common; .net core 开始的时候并没有System.Drawing,在2.0之后新增了 System.Drawing.Common,用于替代原来的System.Drawing.用法基本一致

3. 写接口了

a. 使用特性路由传入想要的尺寸和文件名,这样可以更好的用于前端展示,

b. 没有找到图片或者错误时返回默认的一张图片

c. 需要注意引用 using System.IO;using System.Drawing;

d. .net core 中返回图片不用 HttpResponseMessage 类型,而是直接采用 IActionResult. 而且封装了FileContentResult类,可以直接返回.

e. .net core 中获取当前项目的物理地址可以通过 AppContext.BaseDirectory 和.net 有区别

        /// <summary>
/// 访问图片
/// </summary>
/// <param name="width">所访问图片的宽度,高度自动缩放,大于原图尺寸或者小于等于0返回原图</param>
/// <param name="name">所要访问图片的名称或者相对地址</param>
/// <returns>图片</returns>
[HttpGet]
[Route("file/image/{width}/{name}")]
public IActionResult GetImage(int width, string name)
{
var appPath = AppContext.BaseDirectory.Split("\\bin\\")[] + "/image/";
var errorImage = appPath + "404.png";//没有找到图片
var imgPath = string.IsNullOrEmpty(name) ? errorImage : appPath + name;
//获取图片的返回类型
var contentTypDict = new Dictionary<string, string> {
{"jpg","image/jpeg"},
{"jpeg","image/jpeg"},
{"jpe","image/jpeg"},
{"png","image/png"},
{"gif","image/gif"},
{"ico","image/x-ico"},
{"tif","image/tiff"},
{"tiff","image/tiff"},
{"fax","image/fax"},
{"wbmp","image//vnd.wap.wbmp"},
{"rp","image/vnd.rn-realpix"}
};
var contentTypeStr = "image/jpeg";
var imgTypeSplit = name.Split('.');
var imgType = imgTypeSplit[imgTypeSplit.Length - ].ToLower();
//未知的图片类型
if (!contentTypDict.ContainsKey(imgType))
{
imgPath = errorImage;
}
else
{
contentTypeStr = contentTypDict[imgType];
}
//图片不存在
if (!new FileInfo(imgPath).Exists)
{
imgPath = errorImage;
}
//原图
if (width <= )
{
using (var sw = new FileStream(imgPath, FileMode.Open))
{
var bytes = new byte[sw.Length];
sw.Read(bytes, , bytes.Length);
sw.Close();
return new FileContentResult(bytes, contentTypeStr);
}
}
//缩小图片
using (var imgBmp = new Bitmap(imgPath))
{
//找到新尺寸
var oWidth = imgBmp.Width;
var oHeight = imgBmp.Height;
var height = oHeight;
if (width > oWidth)
{
width = oWidth;
}
else
{
height = width * oHeight / oWidth;
}
var newImg = new Bitmap(imgBmp, width, height);
newImg.SetResolution(, );
var ms = new MemoryStream();
newImg.Save(ms, System.Drawing.Imaging.ImageFormat.Bmp);
var bytes = ms.GetBuffer();
ms.Close();
return new FileContentResult(bytes, contentTypeStr);
}
}

4. 结果如下图

700px 宽度

200px 宽度

最新文章

  1. CentOS 6中MATLAB print函数“所见非所得”bug的解决方案
  2. jQuery 语法
  3. Jetty使用攻略
  4. iOS 顺传
  5. qml ios长按晃动
  6. 【python,排序】几种常用的排序算法,使用python实现
  7. bzoj 3629 [JLOI2014]聪明的燕姿(约数和,搜索)
  8. bzoj3351:[ioi2009]Regions
  9. JSONObject简介(2)
  10. Java集合 - List介绍及源码解析
  11. 杭电ACM2009--求数列的和
  12. JAVA进阶2
  13. 模块——Getopt::Long接收客户命令行参数和Smart::Comments输出获得的命令行参数内容
  14. JmsTemplate sendAndReceive 设置超时
  15. 分享WCF文件传输---WCFFileTransfer
  16. 7. Bagging &amp; Random Forest
  17. JavaSE日常笔记汇总
  18. linux 目录结构(转)
  19. Java线程池可用的队列
  20. 使用django rest framework写POST和GET接口

热门文章

  1. &lt;TCP/IP原理&gt; (二) OSI模型和TCP/IP协议族
  2. linux网络性能测试工具ipref安装与使用
  3. MySql数据库字段排序规则不一致产生的一个问题
  4. maven deploy 指定-DaltDeploymentRepository
  5. ORACLE创建表空间 新建用户 授权
  6. java中53个关键字的意义及使用方法
  7. kubernetes之flannel
  8. netty的简单的应用例子
  9. jquery script两个属性
  10. object-fit、object-position 属性