android 设置网络参数,Android网络请求-sign参数的设置方式
发布日期:2022-02-21 12:50:39 浏览次数:21 分类:技术文章

本文共 3407 字,大约阅读时间需要 11 分钟。

8af8eac2eda5aa3ed317b53350551da0.png

最近做项目,碰着一个奇怪的请求,后台说在调用接口之前需要验证签名和有效时间,当场就懵逼了,要生成一个sign签名,下面来说说怎么做

首先说说大致思路: sign 的生成:按照规则来是键值对的形式(key=value),拼接的时候按照key=value&key=value(注意:key:后台所需的参数名,value:前台所获取到的值)&time=系统所获取的时间&salt = fangzhou(这个参数按照后台要求),而后进行 urlencode 编码(Java中有方法),下一步进行MD5加密,如果需要将加密后的值全部转化为大写(小写),Java中有方法直接调用即可;

接下来说说具体怎么实现:

1.请求数值的拼接(key=value&key=value):

String name = "宋小宝";

String address = "东北";

String panameter = "name="+ name + "& address = "+address;

2.在请求数值的拼接字符串后面加上时间戳和特定值(根据后台要求来)

//获取系统时间戳

Date dt= new Date();

Long timeStamp= dt.getTime();

String signText = panameter +"&time="+timeStamp + "&salt=fangzhou";

3.拼接完成后,对signText进行 urlencode 编码

try {

String urlencoderText = URLEncoder.encode(signText,"utf-8");

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

注:这里会抛出一个异常,直接 try 就可以了,这只是一个Java方法直接调用就完毕了

4.然后进行md5加密

//MD5加密

String md5Text = md5(urlencoderText);

md5加密的方法了,网上有,直接c,v就ok了;

如果要对加密后的值,字母全部转化为大写(小写)直接这样:

//MD5加密

String md5Text = md5(urlencoderText).trim().toUpperCase();

注:这是转化为大写的方法(小写的方法:直接在字符串后面这样加就可以了

.trim().toLowerCase();

这样就可以了;但是你以为这样就完了? 哥们儿,你想的太简单了;下面才是最坑...的时候,怎么形容了,直接上代码吧!

首先说明一点我用的xutils请求框架(具体怎么用我就不说了,相信大家都会用的-中国的程序猿是最棒的);

//设置请求地址

params = new RequestParams(url);

//添加请求参数

params.addBodyParameter("name",name);

params.addBodyParameter("address",address);

//---添加时间戳---

params.addBodyParameter("time",timeStamp+"");

//加密的参数-sign

params.addBodyParameter("sign",md5Text );

看见没有,没有进行转码的请求参数,照样去添加,一个都不能少,反而还多了一个时间戳的参数,但是注意我上面加密了salt请求参数,这里没有添加!!在最后面添加了转码加密后的请求参数-sign

而后就用正常的发请求的流程就可以啦,,,就是这样--完美

总之一句话-先拼接-后转码-再加密-再发请求

补充知识:浅谈URL参数的sign签名认证

以下内容是参考别人的博客内容整理,如有不足之处,敬请指正。。。

大家先思考一个问题: 你在写开放的API接口时是如何保证数据的安全性的?

先来看看有哪些安全性问题在开放的api接口中,我们通过http Post或者Get方式请求服务器的时候,会面临着许多的安全性问题,例如:

1. 请求来源(身份)是否合法?

2. 请求参数被篡改?

3. 请求的唯一性(不可复制)

解决方案:为了保证数据在通信时的安全性,我们可以采用参数签名的方式来进行相关验证。

案列分析

我们通过给某 [移动端(app)] 写 [后台接口(api)] 的案例进行分析:

客户端:以下简称app

后台接口:以下简称api

我们通过app查询产品列表这个操作来进行分析:

app中点击查询按钮==》调用api进行查询==》返回查询结果==>显示在app中

一、不进行验证的方式

api查询接口:

app调用:http://api.test.com/getproducts?参数1=value1.......

如上,这种方式简单粗暴,通过调用getproducts方法即可获取产品列表信息了,但是这样的方式会存在很严重的安全性问题,没有进行任何的验证,大家都可以通过这个方法获取到产品列表,导致产品信息泄露。

那么,如何验证调用者身份呢?如何防止参数被篡改呢?

二、MD5参数签名的方式

我们对api查询产品接口进行优化:

1.给app分配对应的key、secret

2.Sign签名,调用API 时需要对请求参数进行签名验证,签名方式如下:

a. 按照请求参数名称将所有请求参数按照字母先后顺序排序得到:keyvaluekeyvalue...keyvalue 字符串如:将arong=1,mrong=2,crong=3 排序为:arong=1, crong=3,mrong=2 然后将参数名和参数值进行拼接得到参数字符串:arong1crong3mrong2。

b. 将secret加在参数字符串的头部后进行MD5加密 ,加密后的字符串需大写。即得到签名Sign

新api接口代码:

app调用:http://api.test.com/getproducts?key=app_key&sign=BCC7C71CF93F9CDBDB88671B701D8A35&参数1=value1&参数2=value2.......

注:secret 仅作加密使用, 为了保证数据安全请不要在请求参数中使用。

如上,优化后的请求多了key和sign参数,这样请求的时候就需要合法的key和正确签名sign才可以获取产品数据。这样就解决了身份验证和防止参数篡改问题,如果请求参数被人拿走,没事,他们永远也拿不到secret,因为secret是不传递的。再也无法伪造合法的请求。

但是...这样就够了吗?细心的同学可能会发现,如果我获取了你完整的链接,一直使用你的key和sign和一样的参数不就可以正常获取数据了...-_-!是的,仅仅是如上的优化是不够的。。。。。。

请求的唯一性:

为了防止别人重复使用请求参数问题,我们需要保证请求的唯一性,就是对应请求只能使用一次,这样就算别人拿走了请求的完整链接也是无效的。

唯一性的实现:在如上的请求参数中,我们加入时间戳:timestamp(yyyyMMddHHmmss),同样,时间戳作为请求参数之一,也加入sign算法中进行加密。

新的api接口:

app调用:

http://api.test.com/getproducts?key=app_key&sign=BCC7C71CF93F9CDBDB88671B701D8A35&timestamp=201603261407&参数1=value1&参数2=value2.......

如上,我们通过timestamp时间戳用来验证请求是否过期。这样就算被人拿走完整的请求链接也是无效的。

Sign签名安全性分析:

通过上面的案例,我们可以看出,安全的关键在于参与签名的secret,整个过程中secret是不参与通信的,所以只要保证secret不泄露,请求就不会被伪造。

总结

上述的Sign签名的方式能够在一定程度上防止信息被篡改和伪造,保障通信的安全,这里使用的是MD5进行加密,当然实际使用中大家可以根据实际需求进行自定义签名算法,比如:RSA,SHA等加密算法。希望能给大家一个参考,也希望大家多多支持云海天教程。

转载地址:https://blog.csdn.net/weixin_33958381/article/details/117546797 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:android 点击文本框 不调用键盘,Android点击EditText文本框之外任何地方隐藏键盘
下一篇:android+最新手机,最新Android手机性能榜单:骁龙845+8G的它只排第三

发表评论

最新留言

逛到本站,mark一下
[***.202.152.39]2023年05月26日 03时37分49秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

最新文章

linux 的ip 设置lo_LINUX配置IP的三种方式 2019-12-02 03:25:37
authconfig‐tui_2.2. authconfig の使用 2019-12-02 03:25:38
webview 输入法_android webview 输入法键盘遮挡输入框的问题 2019-12-02 03:25:38
f12获取网页文本_F12 - 开发者工具详解 2019-12-02 03:25:38
网站互点工具_网站优化排名做不上需要做的操作 2019-12-02 03:25:38
python相减功能的函数_Python笔记第3章,模块和模块的常用方法,函数式编程yield,三元运算Lambda表达式,内置涵数,常用模块... 2019-12-02 03:25:35
python时间控件readonly属性_人生苦短,我学python之python+selenium js处理日历控件(修改readonly属性)... 2019-12-02 03:25:35
python在mac模拟鼠标点击_macos – 如何通过mac终端模拟鼠标点击? 2019-12-02 03:25:35
manjaro设置字体_Manjaro安装,配置,美化指南 2019-12-02 03:25:36
dtsi与dts_如何看系统到底用了哪个dtsi 2019-12-02 03:25:36
spssχ2检验_spss交叉表分析方法与步骤 + SPSS卡方检验结果的阅读 2019-12-02 03:25:36
element 搜索匹配_Vue Element 分组+多选+可搜索Select选择器实现示例 2019-12-02 03:25:36
进程线程python_Python 进程 线程总结 2019-12-02 03:25:36
将gridcontrol的值传到textedit中_船舶自动化中的开关量、模拟量、数字量是什么?... 2019-12-02 03:25:33
接口隔离原则_趣谈设计模式之接口隔离原则 2019-12-02 03:25:34
table.reload 只刷新table_EXCEL也能实时刷新股票信息~太神奇了 2019-12-02 03:25:34
判断是否是完全二叉树_二叉树高频面试题和答案 2019-12-02 03:25:34
servlet访问中文文件访问不到_电脑小技巧远程访问共享文件夹 2019-12-02 03:25:34
sql 插入新数据 如何处理>等字符_条码打印软件之如何在条码数据插入字符而不被扫描... 2019-12-02 03:25:35
pythonscrollbar布局_python GUI库图形界面开发之PyQt5滚动条控件QScrollBar详细使用方法与实例... 2019-12-02 03:25:35