如何使用Luacurl / Libcurl / Curl和Lua获取HTML代码
2015-4-23 15:10:41
收藏:0
阅读:163
评论:1
我的代码中缺少什么能够获取网站的源代码(感谢@MichalKottman)?
与在Chrome中右键单击并单击“查看页面源代码”一样。
local curl = require "luacurl"
local c = curl.new()
function GET(url)
c:setopt(curl.OPT_URL,url)
c:setopt(curl.OPT_PROXY,“http://myproxy.bla.com:8080”)
c:setopt(curl.OPT_HTTPHEADER,“Connection:Keep-Alive”,“Accept-Language:en-us”)
c:setopt(curl.OPT_CONNECTTIMEOUT,30)
local t = {} - 这将收集结果块
c:setopt(curl.OPT_WRITEFUNCTION,function(param,buf)
table.insert(t,buf)-存储接收到的数据块
return #buf
end)
c:setopt(curl.OPT_PROGRESSFUNCTION,function(param,dltotal,dlnow)
print('%',url,dltotal,dlnow)-在此处进行您的花式报告
end)
c:setopt(curl.OPT_NOPROGRESS,false)-使用此选项来激活进度
assert(c:perform())
return table.concat(t) - 将整个数据作为字符串返回
end
--local s = GET 'http://www.lua.org/'
local s = GET 'https://www.youtube.com/watch?v=dT_fkwX4fRM'
print(s)
file = io.open(“text.html”,“wb”)
file:write(s)
file:close()
很不幸,必须使用Lua和使用luacurl绑定libcurl,因为提供代理时luasocket不能工作(至少对我来说是这样)。
我的下载文件为空。使用cmd我可以毫不费力地获取页面源代码
curl http://mypage.com
对于lua.org,它能够完美地工作,但对于YouTube链接则不能。我错过了什么?
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
local curl = require "luacurl" local c = curl.new() function GET(url) c:setopt(curl.OPT_URL, url) c:setopt(curl.OPT_PROXY, "http://myproxy.com:8080") c:setopt(curl.OPT_HTTPHEADER, "Connection: Keep-Alive", "Accept-Language: en-us") c:setopt(curl.OPT_CONNECTTIMEOUT, 30 ) c:setopt(curl.OPT_FOLLOWLOCATION, true) -- REALLY IMPORTANT ELSE FAIL c:setopt(curl.OPT_USERAGENT, "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.90 Safari/537.36") c:setopt(curl.OPT_SSL_VERIFYPEER, false) -- REALLY IMPORTANT ELSE NOTHING HAPPENS -.- c:setopt(curl.OPT_ENCODING, "utf8") -- could be important local t = {} -- this will collect resulting chunks c:setopt(curl.OPT_WRITEFUNCTION, function (param, buf) table.insert(t, buf) -- store a chunk of data received return #buf end) c:setopt(curl.OPT_PROGRESSFUNCTION, function(param, dltotal, dlnow) print('%', url, dltotal, dlnow) -- do your fancy reporting here end) c:setopt(curl.OPT_NOPROGRESS, false) -- use this to activate progress assert(c:perform()) return table.concat(t) -- return the whole data as a string end