首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    ajax提交等待服务器响应友好提示信息的实现

    众所周知,在客户端向服务器发送AJAX请求时,会有一个等待服务器响应的过程,在网络环境好而且服务器负荷小的时候,业务逻辑不大太复杂的请求可能一下子就处理完并返回响应结果了,但当网络环境不理想或请求涉及到大量的运算时,服务器响应的时间或许就会比较漫长了,特别对于正在操作,正期待操作结果的用户来说,这段等待时候是无比的漫长,如果你没有过这样的操作体验,你回想一下约会时别人迟到的时候或有急事出门时在公交站苦苦等车的滋味,相信你就能感同身受了,而让用户忍受如此煎熬,对于强调用户体验的Web2.0时代,是大忌,是追求“为用户创造价值,让用户享受电子商务所带来的方便快捷”为宗旨的我所不能接受的。虽然,我不能改变客观环境因素带来的长响应时间,但我可以告诉用户系统正在做什么,让他们感受到,系统很在乎他们的感受,并愿意亲切地和他们交流的,而不是传统的软件那样,死板、霸道、冷冰冰的,好了,不多说大道理了,看看我的做法吧。

    03

    详解基于Android App 安全登录认证解决方案

    近几年移动互联网的高速发展,智能手机的使用用户呈现爆炸性增长,手机终端上的App 种类繁多,大多数App 都需要与后台系统进行交互,交互的第一步需要进行登录认证,过于简单的认证方式可能被破解从而造成用户信息的泄露甚至威胁着用户的财产安全。为此基于Android 系统,对比现有几种常见的App 登录认证方式,并提出一种采用RSA 非对称加密和加入Token 时效机制的登录认证解决方案。在登录验证阶段采用RSA 非对称加密方式,App 端对服务器端返回的Token 信息加上时间戳,将处理后的Token 信息保存到本地,后面的每次请求都携带该Token 从而实现免登录的登录状态的保持。

    01

    浅谈如何在C#Winform程序中正确使用登录窗体

    看到很多朋友在CSDN中发帖放分求“如何实现登录验证正确后弹出主窗体”的问题。关于这个问题的实现方法,一般很多人都是使用在登录窗体点击“登录”按钮后,通过后台数据验证正确后,把登录窗体隐藏,然后载入主窗体。还有一种做法是以上提问的这些人的一个不太对的一个实现办法(其实是无法实现的),他们的做法是点击“登录”按钮后,调用this.close()方法去把登录窗体关闭,然后实例化主窗体            frmMain dlg=new frmMain();            dlg.ShowDialog();          用以上代码想实现登录后加载主窗体,你可以发现,当点击“登录”按钮后,登录窗体确实是关闭了,然后程序加载主窗体,主窗体是一闪而过,随即又关闭了。这是为什么呢?其实,你调用登录窗体的关闭事件时,把进程给关了,frmMain和frmLogin窗体是同一个进程,所以就出现了以上的一闪而过的现象。          那么我们如何能够实现验证登录信息正确后加载主窗体呢?我的答案是通过验证返回参数去实现过程控制。          在程序的类库里定义一个全局变量,如Bool  bLoginOk=false;          此变量在未作登录时的初始值为false。          在项目中的Program.cs中,通过先加载frmLogin,点击登录窗体中的“登录”按钮后,在后台查询数据库验证合法性,如果合法,则把bLoginOk赋值true;否则赋值falsse。          在最后通过判断bLoginOk的值         if(bLoginOk==true)        {            Application.run(frmMain);        }       else           Application.Exit();           同样可以通过以上的方法实现验证数据库连接参数的准确性。

    01

    后台登录流程设计

    关于后台登录步骤的流程: 1. 后台登录控制器:RegisterController 1. GetImageValidate()方法说明: 登录页面,加载验证码(防止暴力破解)的时候,需要一个Key在服务器端保存验证码生成的数字值,这个时候在Smart1Controller控制器中,使用了AccessKeyFirst属性(从请求登录页面的链接中获取Access-Token,如果没有则Guid重新生成),同时将获取的这个Access-Token值,设置为Cookie信息存储到浏览器端; 2. SmartController控制器说明: 所有的控制器都将继承SmartController控制器;这个控制器的主要功能是对所有的控制器进行抽象方法:对所有的控制器添加表头属性 [Authorization] , [Authorization] F12进入这个类: 功能主要是:1.用户请求控制器的方法之前先检查服务器端的MemberCache中是否保存了用户的信息(用户是否已经登 录),登录验证; 2. 用户登录了,用户请求某些方法是否有权限的验证; 3. 对没有设置权限的方法,做直接通过验证的处理; 4. 如果用户没有登录,没有权限分别做不同的返回状态值处理返回; 3. Login(LoginBase login)方法说明: 完成验证码的验证: 1.AccessKey属性说明:(获取刚才服务器给浏览器中设置到cookie对象中的Acces-Token值),这个属性 只有获取方法,没有设置方法,目的就是为了只是获取刚才的cookie值,所以这个cookie对象的过期时 间设置的不能过期时间太短,至少一个小时吧,如果在请求登录之前的时候,获取的Acces-Token是空的 ,那么在请求通过登录方法的验证码的时候,肯定是不会通过验证的; 完成用户信息的认证,如果用户的信息验证通过,则在MemberCache中,设置用户的缓存时间,和缓存键,GetKey()方 法设置缓存key;并返回用户的登录信息; 4. LoginOff() 方法说明: 退出页面,清除服务器中MemberCache中的缓存信息;并将浏览器端的cookie信息清除;

    01
    领券