返回顶部
首页 > 资讯 > 精选 >ASP.NET Core中怎么利用 Razor处理Ajax请求
  • 718
分享到

ASP.NET Core中怎么利用 Razor处理Ajax请求

2023-06-19 10:06:32 718人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关ASP.net core中怎么利用 Razor处理ajax请求,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。RazorRazor Pages是ASP.net co

这篇文章将为大家详细讲解有关ASP.net core中怎么利用 Razor处理ajax请求,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

Razor

Razor Pages是ASP.net core的一项新功能,可以使编页面的编程方案更简单,更高效。Razor页面使用处理程序方法来处理传入的Http请求(GET / POST / PUT / Delete)。这些类似于asp.net mvcWEB api的Action方法。Razor Pages遵循特定的命名约定,Handler方法也是如此。他们也遵循特定的命名约定,并与“On”前缀:和HTTP动词一样OnGet(),OnPost()等处理方法也有异步版本:OnGetAsync(),OnPostAsync()等。

介绍完Razor,直接上图

ASP.NET Core中怎么利用 Razor处理Ajax请求

功能很简单,就是个登录。用户点击"登录按钮"后利用Jquery获取文本框的值,异步提交到服务器。很简单的功能,相信大家都写过很多次了。啪啪啪几下代码就撸出来了。

##前台代码<fORM  method="post">            <div class="login-ic">                <i></i>                <input  asp-for="Login.UserName"  id="UserName" />                <div class="clear"> </div>            </div>            <div class="login-ic">                <i class="icon"></i>                <input  id="PassWord" asp-for="Login.PassWord" />                <div class="clear"> </div>            </div>            <div style="margin-top:-0.5em;">                <ul>                 <li>                  <input type="checkbox" id="brand1" value="">                        <label for="brand1">记得我</label>                 </li>                </ul>                <a href="#">                    忘记密码?                </a>            </div>            <div class="log-bwn" style="margin-top:4em;">                <input type="button" value="登录" id="btnLogin">            </div>            <div class="log-bwn" style="margin-top:1em;">                <input type="button" value="注册" onclick="location.href='/user/reGISter'">            </div></form>##Script代码$("#btnLogin").click(function () {            $.post('/user/Login?hanler=LoginIn', { UserName:$("#UserName").val(),                           PassWord:$("#PassWord").val() }, function (data) {                console.log(data);            });        });##后台代码public class LoginModel : PageModel{   
 private UserServiciCasee _userService;  
  public LoginModel(UserServiciCasee userService)    {        _userService = userService;    }    
  
  public void OnGet()    {    }    [BindProperty]  
   public UserLoginDto Login { get; set; }  
   
    public async Task<ActionResult> OnPostLoginInAsync()  
 {        //if (ModelState.IsValid)        //{        //    var user = await _userService.LoginAsync(Login);        //    if (user != null)        //    {        //        return new JSONResult(ApiResult.ToSucess("登录成功!"));        //    }        //    return new jsonResult(ApiResult.ToFail("帐号密码错误!"));        //}        return new JsonResult(ApiResult.ToFail("参数填写错误,请检查!"));    }}

首先解释下/user/Login?hanler=LoginIn这个Url是什么意思,user是我Page下的一个目录,Login是一个页面,LoginIn是页面里面对应的一个方法。这个url的就是把这个请求交给OnPostLoginInAsync()方法处理。至于为什么是LoginIn而不是OnPostLoginInAsync,在文章开头也提到过,这是Rozar的语法限定,不清楚的朋友可以去看下微软的官方文档,写的肯定比我好。。这个代码乍一看,思路很清晰,项目跑起来,走一波看看。

ASP.NET Core中怎么利用 Razor处理Ajax请求

是的,你没看错,响应码400。各种姿势试了半天,就是400,你现在一定想知道,上面的代码有什么问题。那么,上面的代码没有错。原因是,Razor被设计为可以自动防止跨站请求伪造(CSRF / XSRF)攻击。你不必编写任何其他代码。Razor页面中自动包含防伪令牌生成和验证。这里请求失败,是因为POST没有提交AntiForgeryToken。

有两种方法可以添加AntiForgeryToken。

  • 在ASP.Net Core MVC 2.0中,FormTagHelper为html表单元素注入反伪造令牌。例如,Razor文件中的以下标记将自动生成防伪标记:

    <form method="post"><!-- form markup --></form>
  • 明确添加使用 @Html.AntiForgeryToken()

要添加AntiForgeryToken,我们可以使用任何方法。这两种方法都添加了一个隐藏名称的输入类型__RequestVerificationToken。Ajax请求应将请求头中的防伪标记发送到服务器。所以,修改后的Ajax请求看起来像这个样子:

$("#btnLogin").click(function () {            $.ajax({                type: "POST",                url: "/user/Login?handler=LoginIn",                beforeSend: function (xhr) {                    xhr.setRequestHeader("XSRF-TOKEN",                        $('input:hidden[name="__RequestVerificationToken"]').val());                },                data: { UserName: $("#UserName").val(), PassWord: $("#PassWord").val() },                success: function (response) {                    console.log(response);                },                failure: function (response) {                    alert(response);                }            });        });

改良后的代码在发送请求前在请求头中增加了"XSRF-TOKEN"标识,值为表单自动生成的防伪标记。由于“XSRF-TOKEN”是我们自己加的,框架本身不会识别,所以我们需要把这个标记添加到框架:

public void ConfigureServices(IServiceCollection services){    services.AddMvc();    services.AddAntiforgery(o => o.HeaderName = "XSRF-TOKEN");}

关于ASP.net Core中怎么利用 Razor处理Ajax请求就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: ASP.NET Core中怎么利用 Razor处理Ajax请求

本文链接: https://lsjlt.com/news/295483.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • ASP.NET Core中怎么利用 Razor处理Ajax请求
    这篇文章将为大家详细讲解有关ASP.NET Core中怎么利用 Razor处理Ajax请求,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。RazorRazor Pages是ASP.NET Co...
    99+
    2023-06-19
  • ASP.NET中怎么利用Routing处理请求
    ASP.NET中怎么利用Routing处理请求,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。ASP.NET Routing是一个通用的组件,它不涉及到任何具体的...
    99+
    2023-06-17
  • 利用ASP.Net Core中的Razor实现动态菜单
    目录准备1.实现思路2.编码2.1  建立渲染内容填充方法2.2  建立分部视图2.3 调用分布视图准备 1.框架 .netcore  版本 ...
    99+
    2024-04-02
  • 如何在 ASP.NET Core Web API 中处理 Patch 请求
    目录一、概述二、将 Keys 保存在 Input Model 中三、定义 ModelBinderFactory 和 ModelBinder四、在 ASP.NET Core 项目中替换...
    99+
    2023-05-20
    ASP.NET Core Web API 处理 Patch 请求 ASP.NET Core  Patch 请求
  • ASP.NET Core中的Razor页面怎么创建
    这篇文章主要介绍“ASP.NET Core中的Razor页面怎么创建”,在日常操作中,相信很多人在ASP.NET Core中的Razor页面怎么创建问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家...
    99+
    2023-06-29
  • ASP.NET Core中Razor页面的Handlers处理方法详解
    简介 在前一篇文章中,我们讨论了Razor页面。今天我们来谈谈处理方法(Handlers)。 我们知道可以将代码和模型放在 .cshtml 文件里面或与 ...
    99+
    2024-04-02
  • 在 ASP.NET Core Web API 中处理Patch请求的方法
    今天小编给大家分享的是在 ASP.NET Core Web API 中处理Patch请求的方法,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收...
    99+
    2023-07-06
  • ASP.NET Core怎么使用IHttpClientFactory发出HTTP请求
    今天小编给大家分享一下ASP.NET Core怎么使用IHttpClientFactory发出HTTP请求的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章...
    99+
    2023-06-29
  • Vue 中怎么利用Ajax实现跨域请求
    这篇文章给大家介绍Vue 中怎么利用Ajax实现跨域请求,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一.设置config/index.js || proxyTable添加proxyT...
    99+
    2024-04-02
  • ASP.NET中Razor语法怎么使用
    Razor语法是一种在ASP.NET中用于创建动态网页的模板引擎。它允许开发人员将C#或VB.NET代码与HTML标记混合在一起,以...
    99+
    2023-10-23
    ASP.NET Razor
  • SpringBoot+SpringSecurity怎么处理Ajax登录请求
    这篇文章主要讲解了“SpringBoot+SpringSecurity怎么处理Ajax登录请求”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot+SpringSecurity...
    99+
    2023-06-19
  • HTML5中怎么利用postMessage实现Ajax跨域请求
    今天就跟大家聊聊有关HTML5中怎么利用postMessage实现Ajax跨域请求,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 常规的几...
    99+
    2024-04-02
  • 怎么在FormData中利用Ajax请求上传文件
    这篇文章将为大家详细讲解有关怎么在FormData中利用Ajax请求上传文件,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Servlet3.0开始提供了一系列的注解来配置Servlet、Fi...
    99+
    2023-06-08
  • 在ASP.NET Core中用HttpClient发送POST, PUT和DELETE请求
    目录在ASP.NET Core中使用HttpClient发送POST请求使用HttpRequestMessage发送POST请求在ASP.NET Core中使用HttpClient发...
    99+
    2024-04-02
  • 如何使用Servlet处理AJAX请求
    本文小编为大家详细介绍“如何使用Servlet处理AJAX请求”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何使用Servlet处理AJAX请求”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起...
    99+
    2024-04-02
  • Java中的跨域请求怎么利用Ajax jsonp 实现
    这篇文章将为大家详细讲解有关Java中的跨域请求怎么利用Ajax jsonp 实现,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、什么是JSONP一般来说位于 server1.exampl...
    99+
    2023-05-31
    java jsonp ajax
  • ASP.NET Core怎么处理404错误
    这篇文章主要介绍“ASP.NET Core怎么处理404错误”,在日常操作中,相信很多人在ASP.NET Core怎么处理404错误问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”ASP.NET Core怎么处...
    99+
    2023-06-30
  • 前端开发中怎么处理AJAX请求的重复使用
    这篇文章给大家分享的是有关前端开发中怎么处理AJAX请求的重复使用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在开发前端时,我们经常使用AJAX来初始化数据并动态渲染在页面上,...
    99+
    2024-04-02
  • asp.net中怎么利用ajax实现分页
    asp.net中怎么利用ajax实现分页,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。具体如下:这里涉及两个.aspx文件,一...
    99+
    2024-04-02
  • ASP.NET中怎么利用AJAX访问Web Services
    ASP.NET中怎么利用AJAX访问Web Services,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Web Servic...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作