博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ASPNETCOREAPI 跨域处理 SQL 语句拼接 多条件分页查询 ASPNET CORE 核心 通过依赖注入(注入服务)...
阅读量:6824 次
发布时间:2019-06-26

本文共 9810 字,大约阅读时间需要 32 分钟。

AspNetCoreApi 跨域处理

如果咱们有处理过MV5 跨域问题这个问题也不大。

(1)为什么会出现跨域问题:

 浏览器安全限制了前端脚本跨站点的访问资源,所以在调用WebApi 接口时不能成功访问资源,原因“同源策略”的存在

        同源指以下几点相同

              (1) IP地址/域名

              (2) 端口号

              (3) 网络协议)

              以上三点相同即为同源,浏览器将不做限制。

        (同源)   WebFrom 前台Ajax调用后台PageLoad页时 因为是在同一站点,以上三点均满足,也就不会出现跨域的问题。

        (不同源) 比如用微服务开发时,前台和微服务没有在同一台服务器上,虽然端口相同IP不同协议也相同,这时就会出现了跨域的问题了。

  引用脚本时会有例外:

(2)文章以AspNetCore Api 为例

      2.1:首先创建一个CoreAPI的项目(这个就不多说了)

      2.2:确保项目NuGet中引用 AspNetCore.ALL 里面包含 AspNetCore.Cors

 

                  

 

     如果没有右击项目依赖项代开NuGet管理工具

               如图所示查找:

               

 

 

        2.3:在Startup.cs 文件的ConfigureServices方法中注入如下代码:

    (1)第一种

services.AddCors(options => options.AddPolicy("Domain",            builder => builder.WithOrigins("http://a.example.com", "http://c.example.com").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin().AllowCredentials()));

 

    "http://a.example.com", "http://c.example.com" 代表着允许访问的域,就好像给这个域开放了一个权限,允许访问的权限,可以写多个逗号分隔

            (2)第二种

services.AddCors(options => options.AddPolicy("Domain",            builder => builder.AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin().AllowCredentials()));

            //AllowAnyMethod允许跨域策略允许所有的方法:GET/POST/PUT/DELETE 等方法  如果进行限制需要 AllowAnyMethod("GET","POST") 这样来进行访问方法的限制

            //AllowAnyHeader允许任何的Header头部标题    有关头部标题如果不设置就不会进行限制
            //AllowAnyOrigin 允许任何来源
            //AllowCredentials 设置凭据来源

 

    这里是重点不多说了:F12 查看源 阅读注释就明白了。

     

               在项目中可以写 多个services.AddCors() 需要注意的是 Domain1 的区别 咱们可以针对不同的限制些不同的 限制规则

services.AddCors(options => options.AddPolicy("Domain1",            builder => builder.WithOrigins("http://a.example.com", "http://c.example.com").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin().AllowCredentials()));services.AddCors(options => options.AddPolicy("Domain2",            builder => builder.WithOrigins("http://a.example.com", "http://c.example.com").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin().AllowCredentials()));services.AddCors(options => options.AddPolicy("Domain3",            builder => builder.WithOrigins("http://a.example.com", "http://c.example.com").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin().AllowCredentials()));services.AddCors(options => options.AddPolicy("Domain4",            builder => builder.WithOrigins("http://a.example.com", "http://c.example.com").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin().AllowCredentials()));

            为什么做这么多限制呢:其实大家每个请求都包含了很多内容:

                           比如:通过 抓包工具看到的每条请求所包含的请求信息

                             

                          再比如:我们通过HTTP发送请求时进行的设置:下图举例还可以设置更多的设置,这些设置都可以通过

                                        services.AddCors()来进行设置:

                             

                        2.4:在Startup.cs 文件中的Configure()方法中注册我们的   Domain

                             

public void Configure(IApplicationBuilder app, IHostingEnvironment env)        {               app.UseCors("Domain1");            app.UseCors("Domain2");            app.UseCors("Domain3");            app.UseCors("Domain4");        }

 

                      上面操作完之后我们就结束了准备任务现在可以进行使用了:使用方法如下:

                        2.5:使用如下:
                       (1)第一种  action

[HttpGet("{OrderNO}/{BranchID}")]        //启用跨域        [EnableCors("Domain")]        public Object getMultipleOrderDetail(string OrderNO, int OrderNoType, string BranchID)        {            return vM.getMultipleOrderDetail(OrderNO, OrderNoType, BranchID);        }

                      (2)第二种  控制器

//启用跨域    [EnableCors("Domain")]    [Produces("application/json")]    [Route("api/BorrowOrder/[action]")]    public class SP_PartsBorrowOrderController : Controller    {

                        2.6 :前台调用代码如下:

 

                       重点是:这个节点    xhrFields: { withCredentials:true //跨域请求中带cookie },//必须有这项的配置,不然cookie无法发送至服务端

本文是以 CORS 进行实现 

                              转载请注明出处谢谢!

          

 

 

 

 

用17写AspNetCore 也一年了,最近出现了这个问题 :

在点击发布的时候 报错了,构建失败的问题,刚开始还排查日子,删除以往的发布遗留痕迹,后来发现不行,

但是项目在本地运行的时候是好使的,生成也不会报错。

我们项目中有3个解决方案,只有其中一个可以进行发布,我就对项目的(共同引用)进行查看。

这是错误信息:

解决方法:我以前用的是2.0.0版本的,可能在项目中新建的解决方案我引用的是2.0.3的,导致另外两个解决方案发布不了。总之我跟新了 引用包就OK了

 

 

 

 

 

 

Create PROCEDURE [dbo].[Proc_B2B_GetBatchMainPaging]  @StationNo AS varchar(50) , --m  @StationName AS varchar(50) , --m  @PartNo AS varchar(50) ,   -- son  @PartName AS varchar(200) , --son  @IsOldPart AS varchar(1) , --m  @IsRebate AS varchar(1) , --m  @IsTransport AS varchar(1) , --m  @startApplyTime AS varchar(200) ,   --m  @endApplyTime AS  varchar(200) , --m  @startExpectDate AS varchar(200),  --m  @endExpectDate AS varchar(200) , --m  @page AS int , --  @size AS int  -- -- B2B_BatchPartMain as m -- B2B_BatchApprovalDetail as D -- B2B_BatchSendPartInfo as s -- B2B_BatchPartsInfo as sonASBEGINCREATE TABLE #ReturnTable ( [PartNo] varchar(20) NULL , -- son[PartName] varchar(200) NULL , -- son[Counts] DECIMAL(18,2) NULL ,   -- son[ApplyPrice] [decimal](18, 2) NULL,  -- son[ApprovalPrice] [decimal](18, 2) NULL,  -- son[IsOldPart]  [varchar](1) NULL, --m[StationNo] [varchar](8) NOT NULL, --m[StationName][varchar](100) NOT NULL, --m[ExpectDate] [datetime] NULL, --m[OrderStatus] [varchar](4) NULL, --m[ApplyTime] [datetime] NULL, --m[CurrnetApprover] [varchar](20) NULL, --D[ApprovalTime] [datetime] NULL, --D[Supply] [varchar](200) NULL --s);CREATE TABLE #ReturnData ( [PageIndex] varchar(20) NULL , [PageSize] varchar(200) NULL , [totalNumber] varchar(20) NULL , [PageCount] varchar(50) NULL , ); DECLARE @strSql varchar(MAX);    --拼接Sql语句set @strSql='select son.PartNo,son.PartName,son.Counts,son.ApplyPrice,son.ApprovalPrice,m.IsOldPart,m.StationNo,m.StationName,m.ExpectDate,m.OrderStatus,ApplyTime,D.CurrnetApprover,d.ApprovalTime,s.Supplyfrom  B2B_BatchPartMain as m JOIN B2B_BatchPartsInfo as son ON m.BOrderNo=son.BOrderNo JOIN B2B_BatchApprovalDetail as D  ON  m.BOrderNo=D.BOrderNo JOIN B2B_BatchSendPartInfo AS S ON  m.BOrderNo=S.BOrderNo where 1=1'   set @strSql= @strSql + ' AND convert(varchar(100), m.ApplyTime,21)>= ''' + convert(varchar(100), @startApplyTime,21)  + ''' '    set @strSql= @strSql + ' AND convert(varchar(100), m.ApplyTime,21)<= ''' + convert(varchar(100), @endApplyTime,21) + ''' '   set @strSql= @strSql + ' AND convert(varchar(100), m.ExpectDate,21)>= ''' +convert(varchar(100), @startExpectDate,21)  + ''' '    set @strSql= @strSql + ' AND convert(varchar(100), m.ExpectDate,21)<= ''' +convert(varchar(100), @endExpectDate,21)  + ''' '          if( @StationNo is not null)              begin                     set @strSql= @strSql + ' and m.StationNo =''' + @StationNo+'''' ;             end           --判断拼接Sql语句           if( @StationName is not null) and (@StationName!='')             begin                    set  @strSql= @strSql + '  and  m.StationName =''' + @StationName+'''' ;             end           if( @PartNo is not null)and (@PartNo!='')             begin                 set  @strSql= @strSql + ' and son.PartNo =''' + @PartNo+'''' ;             end           if( @PartName is not null)and (@PartName!='')             begin                 set  @strSql= @strSql + ' and  son.PartName =''' + @PartName+'''' ;             end           if( @IsOldPart is not null)and (@IsOldPart!='')             begin                 set  @strSql= @strSql + ' and  m.IsOldPart =''' + @IsOldPart+'''' ;             end           if( @IsRebate is not null)and (@IsRebate!='')             begin                 set  @strSql= @strSql + ' and  m.IsRebate =''' + @IsRebate+'''' ;             end          if( @IsTransport is not null)and (@IsTransport!='')             begin                 set  @strSql= @strSql + ' and   m.IsTransport =''' + @IsTransport+'''' ;             end           --插入数据到临时表      insert INTO #ReturnTable  exec(@strSql) ;      --总数量      DECLARE   @totalNumber  as INT  ;         select @totalNumber=COUNT(PartNo) from #ReturnTable;      -- 总页数      DECLARE @PageCount  as INT  ;         SET @PageCount= Ceiling(@totalNumber*1.0/@size);      --插入返回信息      INSERT into #ReturnData VALUES(@page,@size,@totalNumber,@PageCount)      --分页查询数据      select * from (select ROW_NUMBER() over(order by PartNo asc) as rowNumber  , * from #ReturnTable) as temp  where rowNumber between (((@page-1)*@size)+1) and (@page*@size)      select * from  #ReturnData;      --删除临时表  drop table #ReturnTable
 
 
 
 
 
 
 
 
 

说起依赖注入 相信大家已经很熟悉了,这里我在简要的描述一遍,

 

什么是依赖注入:

       我们从字面意义上来解释一下:依赖代表着两个或者多个对象之间存在某些特定的联系:举一个不是很恰当的例子

                         比如说一度夫妻组成的家庭里没有儿女,咱们暂且把这个家庭当做是一个对象(家),但是他们想要领养一个儿女怎么办,他们想通过福利院去找到这个合适的家庭成员,最终家庭里添加了一位新成员,这里福利院的角色咱们就称为注入者,添加的这个成员的动作就称为注入(DI)。 注入方式有很多,举一个简单的代码例子:

       这是一个构造器注入的例子

 

///         /// 家庭对象        ///         public class family        {            ///             /// 成员            ///             public string member { get; set; }             //构造函数            public family(string Value )             {                member = Value;            }        }

 

 调用代码 如下

 

Console.WriteLine("********************构造器注入******************");            family family = new family("儿子");            string ReturnValue=  family.member;            Console.WriteLine(ReturnValue);            Console.WriteLine("********************构造器注入******************");

 

输出结果:

 

方式有很多种网上资料还是很多的:

回到AspNetCore核心的依赖注入:

     为什么说起这个:因为在Core 的Web程序启动的过程中,是通过Core的启动类Starup 中注册的 配置/和服务 辅助运行。Starup 中配置/和服务就是通过依赖注入注入进去的。

注册MVC服务        这是框架自动生成后的        public void ConfigureServices(IServiceCollection services)        {            services.AddMvc();        }

 

自定义自己的服务    public void ConfigureServices(IServiceCollection services)        {
//增加自己的EF服务 并连接 数据库 services.AddEntityFrameworkSqlServer().AddDbContext
(options => options.UseSqlServer(Configuration.GetConnectionString("SqlServer"))); //增加自己的EF 服务用来记录Log services.AddEntityFrameworkSqlServer().AddDbContext
(options => options.UseSqlServer(Configuration.GetConnectionString("SqlServerLog"))); }

解决方案自动生成的 IOC容器,返回值为 void    如果想引入第三方容器的话需要更改此类的返回值, 返回值需要更改为 IServiceProvider  此接口只有一个方法

   第三方没有用过就不写出来误导人了基本代码如下:

public IServiceProvider ConfigureServices(IServiceCollection services)        {                        services.AddMvc();//在这里写第三方容器        }

也可以在这这地方里注入第三方容器

public IActionResult Index()        {                      //RequestServices  获取或设置系统。提供对请求的访问的iServiceProvider服务容器。            this.HttpContext.RequestServices.GetService();                    return View();        }

 

你可能感兴趣的文章
解析nginx负载均衡
查看>>
python 发送邮件535, 'Error: authentication failed' 解决
查看>>
我的友情链接
查看>>
IPsec ×××的交互模式
查看>>
php-fpm配置多进程池运行
查看>>
软件工程-乱弹
查看>>
进程vs线程
查看>>
基础总结篇之三:Activity的task相关
查看>>
JavaScript的循环方式(1)
查看>>
解析RHCS高可用集群HA及负载均衡集群LB的实现方法
查看>>
聊聊springcloud的serviceRegistryEndpoint
查看>>
蓝鸥零基础学习HTML5第九讲 兼容性七
查看>>
跨交换机实现VLAN
查看>>
XML - JAXP技术 - DOM解析
查看>>
数据操作与查询语句
查看>>
selenium webdriver (11) -- 截图
查看>>
sublime插件安装
查看>>
网络配置多会话实验
查看>>
如何挑选适合自己的HTML5视频课程
查看>>
windows提权
查看>>