wp调用百度服务api

通过百度开放平台申请api成功后,百度会提供一个application key简称ak和一个security key简称sk。

看一下某个服务url的格式

1. url前缀

2. 服务类型

3. 参数

4. md5算法

 

下面是sn签名的方法,得到sn的值。

有个地方要注意的是签名前,先对每个参数值进行一次urlencode转换,拼接后再一次都整个字符串进行了urlencode转换。

 1 Dictionary<string, string> parms = new Dictionary<string, string>();
 2 parms.Add("location", "北京");
 3 parms.Add("output", "json");
 4 parms.Add("ak", "---ak---");
 5 
 6 string queryStr = parms.ToQueryString();
 7 string wholeStr = string.Format("{0}?{1}{2}", "/telematics/v3/weather", queryStr, "---sk---");
 8 string templStr = Uri.EscapeDataString(wholeStr);
 9 
10 string rst = templStr.CreateMD5();
 1 public static string ToQueryString(this Dictionary<string, string> parms)
 2 {
 3     string rst = string.Empty;
 4     if (parms != null && parms.Count > 0)
 5     {
 6         StringBuilder sb = new StringBuilder();
 7         foreach (var item in parms)
 8         {
 9             sb.Append(string.Format("{0}={1}&", item.Key, Uri.EscapeDataString(item.Value)));
10         }
11         sb.Remove(sb.Length - 1, 1);
12         rst = sb.ToString();
13     }
14     return rst;
15 }

md5算法,最后返回十六进制字符串。

 1 public static string CreateMD5(this string str)
 2 {
 3     string strAlgName = Windows.Security.Cryptography.Core.HashAlgorithmNames.Md5;
 4     Windows.Security.Cryptography.Core.HashAlgorithmProvider objMacProv = Windows.Security.Cryptography.Core.HashAlgorithmProvider.OpenAlgorithm(strAlgName);
 5 
 6     Windows.Storage.Streams.IBuffer data = Windows.Security.Cryptography.CryptographicBuffer.ConvertStringToBinary(str, Windows.Security.Cryptography.BinaryStringEncoding.Utf8);
 7     Windows.Storage.Streams.IBuffer hash = objMacProv.HashData(data);
 8 
 9     return Windows.Security.Cryptography.CryptographicBuffer.EncodeToHexString(hash);
10 }

 

最后可以通过浏览器验证一下结果。那么在wp可以通过System.Net.Http.HttpClient GetStringAsync得到返回的json数据。

转载于:https://www.cnblogs.com/yuefei/p/4026597.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WP-REST-API 是WordPress 的一种接口,它通过提供标准化的RESTful API,允许开发人员使用HTTP请求来访问和操作WordPress站点的内容和数据。通过这个接口,开发人员可以使用不同的编程语言和技术来与WordPress进行交互,从而使得开发更加灵活和自由。 JWT(JSON Web Token)是一种用于认证和授权的开放标准。它通过将用户信息和权限信息编码成一种加密的令牌,以实现跨服务器和跨域的身份验证。JWT 是由三部分组成的:头部、负载和签名。头部包含令牌的加密算法和类型信息,负载包含用户的相关信息,签名用于验证令牌的真实性和完整性。 WP-REST-API JWT整合了WordPress的REST API和JWT的认证机制,使得在使用WP-REST-API进行开发的过程中,可以增加身份验证和授权的功能。它允许开发人员在请求WordPress REST API时,通过在请求头或参数中提供有效的JWT令牌来验证用户的身份和权限,并根据令牌中的负载信息来进行授权。 WP-REST-API JWT的使用具有很多优势。首先,它提供了一种轻量级的身份验证方式,减少了开发的复杂性。其次,通过JWT令牌的机制,可以实现无状态的认证和授权,提高了性能和可扩展性。此外,JWT还提供了一种可靠的机制来防止伪造和篡改请求数据,增强了系统的安全性。 总而言之,WP-REST-API JWT为开发人员提供了一种方便、灵活和安全的方式来使用WordPress的REST API。它简化了身份验证和授权的过程,并通过使用JWT令牌提高了系统的性能和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值