当前位置: 首页 > news >正文

asp.net mvc做网站难吗贵州省建设厅网站查

asp.net mvc做网站难吗,贵州省建设厅网站查,网站建设数据库选择,google谷歌搜索主页gin框架39--重构 BasicAuth 中间件 介绍gin BasicAuth 解析自定义newAuth实现基础认证注意事项说明 介绍 每当我们打开一个网址的时候#xff0c;会自动弹出一个认证界面#xff0c;要求我们输入用户名和密码#xff0c;这种BasicAuth是最基础、最常见的认证方式#xff0… gin框架39--重构 BasicAuth 中间件 介绍gin BasicAuth 解析自定义newAuth实现基础认证注意事项说明 介绍 每当我们打开一个网址的时候会自动弹出一个认证界面要求我们输入用户名和密码这种BasicAuth是最基础、最常见的认证方式gin框架中提供了一种内置的方式但它只能用内置的用户和密码无法使用外部db中的用户和密码这种方式很多时候是不友好的。 为此本文根据gin.BasicAuth的原理对其就行重构实现一个简单的newAuth中间件该中间件可以代替默认的BasicAuth并且可以按需更改为自定义查询函数实现从外部db或者用户管理系统查询信息实现登录认证的功能。 gin BasicAuth 解析 博文 gin框架14–使用 BasicAuth 中间件 介绍了BasicAuth 中间件的基础使用方法直接使用 gin.BasicAuth(gin.Accounts{“foo”: “bar”, “austin”: “1234”, “lena”: “hello2”, “manu”: “4321”, }) 即可非常简单实用。 实际上当我们访问url的时候它会从请求的 Authorization 中获取用户信息并和gin.Accounts中内置用户对比如果用户存在就将用户名称存放在Context的 Keys map结构中方便后续查找或者获取用户信息如果不存在就设置c.Header(“WWW-Authenticate”, realm), 并返回c.AbortWithStatus(http.StatusUnauthorized)浏览器上的表现就是重新弹出输入用户名和密码的窗口 。 核心逻辑在 BasicAuthForRealm 方法中如下所示: func BasicAuthForRealm(accounts Accounts, realm string) HandlerFunc {if realm {realm Authorization Required}realm Basic realm strconv.Quote(realm)pairs : processAccounts(accounts)return func(c *Context) {// Search user in the slice of allowed credentialsuser, found : pairs.searchCredential(c.requestHeader(Authorization))if !found {// Credentials doesnt match, we return 401 and abort handlers chain.c.Header(WWW-Authenticate, realm)c.AbortWithStatus(http.StatusUnauthorized)return}// The user credentials was found, set users id to key AuthUserKey in this context, the users id can be read later using// c.MustGet(gin.AuthUserKey).c.Set(AuthUserKey, user)} }自定义newAuth实现基础认证 gin.BasicAuth 只能提供默认的认证功能且需要内置指定的用户|密码但实际在代码中hardcode大量用户信息是不科学的因此我们需要自己重构一个BasicAuth来实验基础认证功能。 此处实现了一个newAuth中间件该中间件会判断用户是否输入账号|密码并通过judgeUserExist来判断账号|密码是否正确正确则返回用户信息不正确则返回http.StatusUnauthorized 具体案例如下。 此处为了简洁方便此处直接内置了3个用户到users中并用 judgeUserExist 查询用户账号密码是否正确。实际项目中可将该方法更改为查询db无需在项目中hardcode内置用户。 package mainimport (encoding/base64fmtgithub.com/gin-gonic/ginnet/httpstrconvstrings )var users gin.H{foo: gin.H{email: foobar.com, phone: 123433, pwd: bar},austin: gin.H{email: austinexample.com, phone: 666, pwd: 123},lena: gin.H{email: lenaguapa.com, phone: 523443, pwd: 456}, }func help() string {helpStr : hello gin: 127.0.0.1:8088/your-api /auth/user return helpStr }func judgeUserExist(userName, userPwd string) (string, bool) {// 实际项目中将该函数更改为从db查询即可此处为了简单直接从预定的users中查询。msg : tag : falseif userInfo, ok : users[userName]; ok {pwd, ok : userInfo.(gin.H)[pwd]if ok pwd userPwd {msg fmt.Sprintf(用户%v密码正确, userName)tag true} else {msg fmt.Sprintf(用户%v密码不正确, userName)}} else {msg fmt.Sprintf(用户%v不存在, userName)}return msg, tag }func getUserPwdFromAuthorization(auth string) (user, pwd string) {// auth[:6]Basic base64UserPwd, err : base64.StdEncoding.DecodeString(auth[6:])if err ! nil {panic(err)}base64UserPwdStr : string(base64UserPwd)colonIndex : strings.Index(base64UserPwdStr, :)user base64UserPwdStr[:colonIndex]pwd base64UserPwdStr[colonIndex1:]return user, pwd }func newAuth(realm string) func(c *gin.Context) {if realm {realm Authorization Required}realm Basic realm strconv.Quote(realm)return func(c *gin.Context) {authHeader : c.Request.Header.Get(Authorization) // 获取请求头中的数据if authHeader {c.Header(WWW-Authenticate, realm)c.AbortWithStatus(http.StatusUnauthorized)return} else {user, pwd : getUserPwdFromAuthorization(authHeader)// fmt.Printf(user%v,pwd%v\n, user, pwd)msg, tag : judgeUserExist(user, pwd)if !tag {// c.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{msg: msg, tag: tag})fmt.Println(msg)c.AbortWithStatus(http.StatusUnauthorized)return}c.Set(gin.AuthUserKey, user)}} }func userHandler(c *gin.Context) {user : c.MustGet(gin.AuthUserKey).(string)c.IndentedJSON(http.StatusOK, gin.H{status: 200,msg: its fine,userInfo: users[user],}) }func main() {app : gin.Default()app.GET(/, func(c *gin.Context) {c.String(http.StatusOK, help())})authorized : app.Group(/auth, newAuth())authorized.GET(/user, userHandler)app.Run(:8088) }输出: 注意事项 c.Header中需要添加 WWW-Authenticate 字段否则初次访问的时候不会弹出输入用户名、密码的框!!! 说明 测试环境 ubuntu22.04 Desktop go1.20.7参考文档 using-basicauth-middleware Gin框架 -- 中间件
http://www.hkea.cn/news/14420930/

相关文章:

  • 现在做个人网站汽贸公司网站建设
  • 工信部网站备案查询系统江门市专业做网站公司
  • 网站app推广怎么做室内设计公司经营范围
  • 手机浏览器 网站开发临沂建站公司
  • 网站建设数据库代码wordpress 分享 qq
  • 网站地址搜索网络服务提供者发现未成年通过网络发布
  • 网站设计网页主页介绍wordpress 即时通讯
  • 淘宝网站建设手机版什么网站可以做数据图
  • 赣州网站建设jx25懒人网页编辑器手机版
  • 服务器iis搭建网站东莞网站推广怎么做
  • 网站推广和优化的原因网络营销稷山网站建设
  • 医生在网站上做自我宣传网站设计制作ihanshi
  • ps做网站头部的图做俄罗斯网站
  • 网站内容建设怎么写无锡工程造价信息网
  • 适合seo优化的站点洛阳做网站公司
  • 网站业务费如何做记账凭证短视频seo关键词
  • 求一个手机能看的2022站群网站和做seo那个号
  • 电子商务网站建设需要做好哪些准备6广州文化网站模板
  • 网站建设和利用情况中国源码资源网
  • 旅游景点网站设计国内展厅设计公司排名
  • 一站式做网站报价dede做漫画网站的案例
  • 订餐网站开发什么是seo是什么意思
  • 织梦如何做中英文版的网站深圳设计装修公司
  • 垂直门户网站移动互联网开发好就业吗
  • 做计算机网站有哪些内容本地的镇江网站建设
  • 凤岗网站设计wordpress 模板带数据
  • 晋中市住房保障和城乡建设局网站网站策划编辑招聘
  • 北京网站优化软件公司运营培训班学费大概多少
  • 大连在哪个网站做网上核名上海网站哪家好
  • 河南英文网站建设公司html5效果网站