PC端访问却变成移动端地址问题#python#scrapy
问题描述
用scrapy 爬取喜马拉雅,爬取PC端地址,入口链接的response没问题,但后面response看到的是移动端地址。。。。
spider 代码如下:
class SpxmlySpider(scrapy.Spider): name = ’ximalaya’ allowed_domains = ['ximalaya.com'] # 保存每页链接 start_urls = [’http://www.ximalaya.com/dq/all/{}’.format(num) for num in range(2, 3)] #先改为第二页试试 def parse(self, response):# 取出专辑链接print(response)mainurls = response.xpath(’//p[@class='albumfaceOutter']/a/@href’).extract()# for url in mainurls:# yield Request(url = url, callback=self.parse_details)print(mainurls[0])yield Request(url = mainurls[0], dont_filter=True, callback = self.parse_details)# TODO 为什么PC端访问会变成移动地址问题!!!!!!!!!!!!!!!!! def parse_details(self, response):item = XimalayaItem()print(response)......以下省略
控制台输出:

已经写了一个 middlewares.RotateUserAgentMiddleware,是生效的,输出内容也可以看出来。
是不是触发什么反爬机制?
问题解答
回答1:应该是你的headers没有设置user-agent的原因
回答2:request headers 好好配置一下, 判断是不是移动端一般是靠user-agent啥都没有也能访问到数据,也说明目标网站没怎么在意防盗链
相关文章:
1. angular.js - protractor初学 参考案例运行测试文件 报Error: Timeout2. docker安装后出现Cannot connect to the Docker daemon.3. android - 如何缩小APK的体积4. angular.js - angular post的Content-Type被设置,导致不能上传图片,求助!!5. javascript - 奇怪的Symbol的问题6. javascript - 在vue-cli引入vux后 使用报错7. css - 移动端 盒子内加overflow-y:scroll后 字体会变大8. javascript - JS new Date() 保存到 mongodb 中会早8个小时,我们这里是东八区,mongodb 保存的是格林尼治时间9. docker api 开发的端口怎么获取?10. position:absolute、float、display:inline-block 都能实现相同效果,区别是什么?

网公网安备