MVC+EF API --2

一、 MVC+EF

不管是MvcHAIS Ef 都有文件夹Controller

二、Link查询

  • 多表联查

  • 匿名类型

    三、Postman使用

四、mvc访问使用API

  • 跨域设置:(直接复制粘贴)

  • 跨域请求(在UI层的Web.config 中<system.webServer>中的 </handlers> 下面)

  • <!--跨域请求:三个配置信息-->
      <httpProtocol>
        <customHeaders>
          <!--响应类型 (值为逗号分隔的一个字符串,表明服务器支持的所有跨域请求的方法)-->
          <add name="Access-Control-Allow-Methods" value="GET,POST,PUT,DELETE,OPTIONS"/>
          <!--响应头设置(Content-Type:只限于三个值application/x-www-form-urlencoded、multipart/form-data、text/plain)-->
          <add name="Access-Control-Allow-Headers" value="x-requested-with,content-type"/>
          <!--如果设置 Access-Control-Allow-Origin:*,则允许所有域名的脚本访问该资源-->
          <add name="Access-Control-Allow-Origin" value="*" />
          <!--<add name="Access-Control-Allow-Origin" value="http://domain1.com, http://domain2.com" /> 设置允许跨域访问的网址-->
        </customHeaders>
      </httpProtocol>
  • 跨域设置(UI层的Global.asax 中 直接粘贴到原本方法下面)

  • /// <summary>
          /// 跨域设置
          /// </summary>
          protected void Application_BeginRequest()
          {
              //OPTIONS请求方法的主要作用:
              //1、获取服务器支持的HTTP请求方法;也是黑客经常使用的方法。
              //2、用来检查服务器的性能。如:AJAX进行跨域请求时的预检,需要向另外一个域名的资源发送一个HTTP OPTIONS请求头,用以判断实际发送的请求是否安全。
              if (Request.Headers.AllKeys.Contains("Origin") && Request.HttpMethod == "OPTIONS")
              {
                  //表示对输出的内容进行缓冲,执行page.Response.Flush()时,会等所有内容缓冲完毕,将内容发送到客户端。
                  //这样就不会出错,造成页面卡死状态,让用户无限制的等下去
                  Response.Flush();
              }
          }
  • 在MVC中

  • 用ajax显示分页查询

<input type="text" id="SName" />
<select id="nclass">
  <option>请选择</option>
</select>
<input type="button" value="查询" onclick="Show()" />
<table class="table table-hover">
  <thead>
      <tr>
          <td>ID</td>
          <td>学生姓名</td>
          <td>班级</td>
      </tr>
  </thead>
  <tbody id="tbd">
  </tbody>
</table>
<a href="#" onclick="Page('F')">首页</a>
<a href="#" onclick="Page('N')">下页</a>
<a href="#" onclick="Page('P')">上页</a>
<a href="#" onclick="Page('L')">尾页</a>
<script>
  var pageindex = 1;
  var pagesize = 3;
  var totalcount = 0;
  var totalpage = 0;
  var NId = "";
  var SName = "";
  $(function () {
      Show();
      nclass();
  })
  function Show() {
      $.get('http://localhost:59125/api/Student/Show?NId=' + NId + '&SName=' + SName + '&pageindex=' + pageindex + '&pagesize=' + pagesize + '', res => {
          //给总页数和总条数赋值
          totalcount = res.totalcount;
          totalpage = res.totalpage;
          SName = $("#SName").val();
          NId = $("#nclass").val();
          $("#tbd").empty();
          $(res.list).each(function () {

              $("#tbd").append('<tr>' +
                  '<td>' + this.Id + '</td>' +
                  '<td>' + this.SName + '</td>' +
                  '<td>' + this.NName + '</td>' +
                  +'</tr>');
          });
      });

  }
  //分页
  function Page(o) {
      switch (o) {
          case 'F':
              pageindex = 1;
              break;
          case 'P':
              pageindex = pageindex <= 1 ? pageindex : pageindex - 1;
              break;
          case 'N':
              pageindex = pageindex >= totalpage ? pageindex : pageindex + 1;

              break;
          case 'L':
              pageindex = totalcount;
              break;
      }
      Show();
  }
//下拉框
  function nclass() {
      $.get('http://localhost:59125/api/Student/nclass', res => {
          $(res).each(function () {
              $("#nclass").append(
                  '<option value="' + this.NId + '">' + this.NName + '</option>'
              )
          })
      });
  }
</script>

RESTful风格编写接口

Cors跨域

MVC+EF API 跨域的更多相关文章

  1. .net IIS MVC Rest api 跨域 PUT DELETE 404 无法使用问题解决方案

    一.WebConfig配置法(system.webServer 重点是 httpProtocol handlers) http://www.jinxuliang.com/blog/article/re ...

  2. ASP.NET MVC中设置跨域

    ASP.NET MVC中设置跨域 1.什么是跨域请求 js禁止向不是当前域名的网站发起一次ajax请求,即使成功respone了数据,但是你的js仍然会报错.这是JS的同源策略限制,JS控制的并不是我 ...

  3. js基础 js自执行函数、调用递归函数、圆括号运算符、函数声明的提升 js 布尔值 ASP.NET MVC中设置跨域

    js基础 目录 javascript基础 ESMAScript数据类型 DOM JS常用方法 回到顶部 javascript基础 常说的js包括三个部分:dom(文档document).bom(浏览器 ...

  4. ASP.NET MVC 实现AJAX跨域请求方法《1》

    ASP.NET MVC 实现AJAX跨域请求的两种方法 通常发送AJAX请求都是在本域内完成的,也就是向本域内的某个URL发送请求,完成部分页面的刷新.但有的时候需要向其它域发送AJAX请求,完成数据 ...

  5. 【转载】ASP.NET MVC设置允许跨域访问

    默认情况下,浏览器端发送Ajax请求一般被禁止跨域访问,如A域名网站访问B域名网站的请求会被终止,在ASP.NET MVC项目中,我们可以配置相应的设置项,允许网站的接口跨域访问,主要需要设置Acce ...

  6. Web Api跨域访问配置及调用示例

    1.Web Api跨域访问配置. 在Web.config中的system.webServer内添加以下代码: <httpProtocol> <customHeaders> &l ...

  7. vue使用axios调用豆瓣API跨域问题

    最近做了一个vue小demo,使用了豆瓣开源的API,通过ajax请求时需要跨域才能使用.   封面.jpg 一.以下是豆瓣常用的开源接口: 正在热映 :https://api.douban.com/ ...

  8. ASP.NET MVC 实现 AJAX 跨域请求

    ASP.NET MVC 实现AJAX跨域请求的两种方法 和大家分享下Ajax 跨域的经验,之前也找了好多资料,但是都不行,后来看到个可行的修改了并测试下 果然OK了   希望对大家有所帮助! 通常发送 ...

  9. Laravel API跨域访问的实现步骤

    本篇文章给大家带来的内容是关于Laravel API跨域访问的实现步骤,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 服务器A请求服务器B的接口,那么一般会出现跨域问题. 1 XML ...

  10. web api 跨域请求,ajax跨域调用webapi

    1.跨域问题仅仅发生在Javascript发起AJAX调用,或者Silverlight发起服务调用时,其根本原因是因为浏览器对于这两种请求,所给予的权限是较低的,通常只允许调用本域中的资源,除非目标服 ...

随机推荐

  1. IIS7无法访问.apk文件的解决方法

    随着智能手机的普及,越来越多的人使用手机上网,很多网站也应手机上网的需要推出了网站客户端,.apk文件就是安卓(Android)的应用程序后缀名,默认情况下,使用IIS作为Web服务器的无法访问下载此 ...

  2. 7.29-bug计算器

    <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8 ...

  3. IEEE 802.66( WiMax)的衰亡

    1.什么是WiMax WiMAX全称为,World Interoperability for Microwave Access,即全球微波接入互操作性,是一项基于IEEE 802.16标准的宽带无线接 ...

  4. flutter SliverPersistentHeader子组件透明度渐变【滑动悬停appbar添加自定义组件的透明度】

    在开发flutter悬停头部中,发现一个问题. 我们通常使用SliverAppBar(),去实现悬停的功能,在使用appbar的时候满足不了我们的需求,就需要自定义, 如下:在title中写了一个搜索 ...

  5. C语言标准 —— C89(C90)、C99、C11、C17、C2X

    https://blog.csdn.net/u010217055/article/details/128957497

  6. IO学习笔记7

    2.4 多路复用javaAPI 在上面我们简单java代码实现了多路复用,是一个单线程版的.讲上面的epoll代码复制到linux服务器中,使用strace追踪系统调用. javaAPI会根据系统类型 ...

  7. 无锡哲讯谈饲料加工行业ERP的功能

    我国饲料生产与国际先进水平很接近,也是专业化水平较高的行业.随着社会分工的进一步明确,饲料产品的专业化配送将是未来发展的方向.在一些发达国家,专业化的散装配料车已经普遍应用,我国虽然也有这种形式,但是 ...

  8. ChatGPT 爆火!真有那么神?设计师会失业吗?

    人工智能来了,咱们是不是都要失业了呢? 一款AI产品,在科技市场和资本市场掀起了一阵风暴. 一切的源头,来自一个由美国人工智能公司OpenAI开发的一种大型语言模型ChatGPT.它采用了Transf ...

  9. 【Java学习Day07】标识符

    标识符 Java使用的组成部分的需要名字.类名.变量名以及方法名都被称为标识符 标识符的注意点 所有的标识符都应该以字母(A-Z或者a-z),美元符($).或者下划线(_)开始 首字符之后可以是字母( ...

  10. php curl方法封装

    /** * @desc 获取设备的监控项实时值 * * @return url请求地址 * @return method  请求方法(POST,GET,PUT)等 * @return postfiel ...