当前位置:首页 > 文章列表 > 文章 > php教程 > PHP 实现简单爬虫:file_get_contents 与正则应用

PHP 实现简单爬虫:file_get_contents 与正则应用

2026-05-19 23:48:39 0浏览 收藏
本文深入探讨了使用 PHP 的 `file_get_contents` 搭配正则表达式实现轻量级网页爬虫的核心要点与实战陷阱:既阐明了其依赖 `allow_url_fopen` 的前提条件及被禁用时必须转向 cURL 的刚性限制,也直击正则解析 HTML 的常见误区——如缺失 `s` 修饰符、贪心匹配导致的误捕与漏捕,并给出更健壮的模式设计建议;同时理性对比了正则与 DOMDocument 的适用边界,强调在结构简单、字段固定的场景下,前者凭借启动快、无依赖、代码简洁的优势依然高效可靠;最后提醒开发者绝不能忽视基础防护——模拟 User-Agent、添加请求延迟、控制超时与重定向、严格校验 URL 等,尤其点明正则对 JavaScript 动态渲染页面的天然失效,避免读者陷入“调参即万能”的认知误区。

如何用 PHP 实现一个简单的爬虫程序_使用 file_get_contents 与正则

file_get_contents 能否直接抓取网页内容

能,但有前提:目标网站允许被访问,且 PHP 配置启用了 allow_url_fopen(默认开启,但部分共享主机已禁用)。如果返回空或警告 Warning: file_get_contents(): failed to open stream: no suitable wrapper,说明已被禁用,此时必须改用 cURL —— file_get_contents 在这种情况下完全不可用。

实际使用时建议先检测:

if (!ini_get('allow_url_fopen')) {
    die('file_get_contents 无法用于远程 URL');
}

正则匹配 HTML 标签的常见翻车点

preg_match 提取标题、链接等字段时,最常犯的错误是写 /(.*?)<\/title>/i</code> 这类“贪心+无边界”的表达式。它在遇到换行、注释、嵌套标签(如 <code><script>document.write('<title>...')</code>)时极易误匹配或漏匹配。</p> <p>更稳妥的做法是:</p> <ul><li>加上 <code>s</code> 修饰符让 <code>.</code> 匹配换行符:<code>/<title>(.*?)<\/title>/is</code></li> <li>用非贪婪 + 明确字符集替代 <code>.*?</code>,例如提取 href:<code>/href=["\']([^"\'>\s]+)["\']/i</code></li> <li>避免匹配跨多行的复杂结构(如整个 <code><table></code>),正则不是 HTML 解析器</li> </ul><h3>为什么不用 DOMDocument 而坚持用正则</h3> <p>不是不能用,而是场景不同。如果你只是从格式稳定、结构扁平的页面中提取几个固定字段(比如某天气页的温度数字、某 RSS 源的 <code><link></code> 值),<code>file_get_contents</code> + <code>preg_match</code> 组合启动快、依赖少、代码短。而 <code>DOMDocument</code> 需要加载完整文档树,对 malformed HTML 容错虽好,但开销大,且容易因编码问题(如页面声明 <code>gb2312</code> 但内容是 <code>utf-8</code>)导致解析失败或乱码。</p> <p>若真要用正则提链接,注意两点:</p> <ul><li>用 <code>mb_convert_encoding</code> 统一转为 UTF-8 再匹配,否则中文 URL 可能截断</li> <li>匹配后对结果调用 <code>urldecode</code> 和 <code>filter_var($url, FILTER_VALIDATE_URL)</code> 做基础校验</li> </ul><h3>简单爬虫必须加的防护措施</h3> <p>哪怕只是本地调试,不加限制的 <code>file_get_contents</code> 请求也容易触发目标站的反爬机制或造成自身 IP 被封。最小可行防护包括:</p> <ul><li>设置请求头模拟浏览器:<code>stream_context_create(['http' => ['header' => "User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36\n"]])</code></li> <li>加延迟:<code>sleep(1)</code>,别连续请求</li> <li>限定最大响应体大小,防止下载整站:<code>'max_redirects' => 3, 'timeout' => 10, 'ignore_errors' => true</code></li> <li>始终检查返回值是否为 <code>false</code>,而非只看长度——网络中断时可能返回空字符串,但不是错误</li> </ul><p>真正要注意的是:正则永远无法可靠处理动态渲染页面(如 React/Vue 生成的内容),这类页面源码里根本没你想要的数据,再调什么上下文、修饰符都没用。</p><p>文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《PHP 实现简单爬虫:file_get_contents 与正则应用》文章吧,也可关注golang学习网公众号了解相关技术文章。</p> </div> <div class="labsList"> </div> <div class="cateBox"> <div class="cateItem"> <a href="/article/604516.html" title="scoped属性的作用及HTML样式隔离解析" class="img_box"> <img src="/uploads/20260519/17792057026a0c864680dab.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="scoped属性的作用及HTML样式隔离解析">scoped属性的作用及HTML样式隔离解析 </a> <dl> <dt class="lineOverflow"><a href="/article/604516.html" title="scoped属性的作用及HTML样式隔离解析" class="aBlack">上一篇<i></i></a></dt> <dd class="lineTwoOverflow">scoped属性的作用及HTML样式隔离解析</dd> </dl> </div> <div class="cateItem"> <a href="/article/604518.html" title="PySerial 串口通信实用教程" class="img_box"> <img src="/uploads/20260519/17792057786a0c869272c71.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="PySerial 串口通信实用教程"> </a> <dl> <dt class="lineOverflow"><a href="/article/604518.html" class="aBlack" title="PySerial 串口通信实用教程">下一篇<i></i></a></dt> <dd class="lineTwoOverflow">PySerial 串口通信实用教程</dd> </dl> </div> </div> </div> </div> <div class="leftContBox pt0"> <div class="pdl20"> <div class="contTit"> <a href="/articlelist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit">最新文章</div> </div> </div> <ul class="newArticleList"> <li> <div class="contBox"> <a href="/article/620151.html" class="img_box" title="PHP 表单校验错误怎么回填:保留输入、定位字段和友好提示"> <img src="/uploads/20260702/1782961488-php-form-error-refill.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 表单校验错误怎么回填:保留输入、定位字段和友好提示"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  2天前  |   <a href="/articletag/1433_new_0_1.html" class="aLightGray" title="PHP">PHP</a> · <a href="/articletag/5304_new_0_1.html" class="aLightGray" title="错误提示">错误提示</a> · <a href="/articletag/39947_new_0_1.html" class="aLightGray" title="表单校验">表单校验</a> · <a href="/articletag/39991_new_0_1.html" class="aLightGray" title="用户体验">用户体验</a> · <a href="/articletag/40122_new_0_1.html" class="aLightGray" title="服务端验证">服务端验证</a> · <a href="javascript:;" class="aLightGray" title="用户体验">用户体验</a> <a href="javascript:;" class="aLightGray" title="表单校验">表单校验</a> <a href="javascript:;" class="aLightGray" title="服务端验证">服务端验证</a> <a href="javascript:;" class="aLightGray" title="PHP教程">PHP教程</a> <a href="javascript:;" class="aLightGray" title="错误回填">错误回填</a> <a href="javascript:;" class="aLightGray" title="字段错误">字段错误</a> <a href="javascript:;" class="aLightGray" title="旧输入">旧输入</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620151.html" class="aBlack" target="_blank" title="PHP 表单校验错误怎么回填:保留输入、定位字段和友好提示">PHP 表单校验错误怎么回填:保留输入、定位字段和友好提示</a> </dt> <dd class="cont2"> <span><i class="view"></i>134浏览</span> <span class="collectBtn user_collection" data-id="620151" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620140.html" class="img_box" title="PHP Session 迁移到 Redis:从本机文件到集中存储的回归检查清单"> <img src="/uploads/20260701/1782893643-php-session-files-risk.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP Session 迁移到 Redis:从本机文件到集中存储的回归检查清单"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  3天前  |   <a href="/articletag/220_new_0_1.html" class="aLightGray" title="Redis">Redis</a> · <a href="/articletag/3600_new_0_1.html" class="aLightGray" title="迁移">迁移</a> · <a href="/articletag/4365_new_0_1.html" class="aLightGray" title="session">session</a> · <a href="/articletag/39782_new_0_1.html" class="aLightGray" title="php教程">php教程</a> · <a href="/articletag/39862_new_0_1.html" class="aLightGray" title="登录态">登录态</a> · <a href="javascript:;" class="aLightGray" title="redis">redis</a> <a href="javascript:;" class="aLightGray" title="session">session</a> <a href="javascript:;" class="aLightGray" title="phpredis">phpredis</a> <a href="javascript:;" class="aLightGray" title="PHP教程">PHP教程</a> <a href="javascript:;" class="aLightGray" title="session.save_handler">session.save_handler</a> <a href="javascript:;" class="aLightGray" title="分布式登录">分布式登录</a> <a href="javascript:;" class="aLightGray" title="回归检查">回归检查</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620140.html" class="aBlack" target="_blank" title="PHP Session 迁移到 Redis:从本机文件到集中存储的回归检查清单">PHP Session 迁移到 Redis:从本机文件到集中存储的回归检查清单</a> </dt> <dd class="cont2"> <span><i class="view"></i>145浏览</span> <span class="collectBtn user_collection" data-id="620140" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620114.html" class="img_box" title="PHP 老接口迁移变更单:从散落 $_POST 到 Request DTO 与统一错误响应"> <img src="/uploads/20260630/1782803371-php-dto-migration-entry.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 老接口迁移变更单:从散落 $_POST 到 Request DTO 与统一错误响应"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  4天前  |   <a href="/articletag/1223_new_0_1.html" class="aLightGray" title="参数校验">参数校验</a> · <a href="/articletag/1433_new_0_1.html" class="aLightGray" title="PHP">PHP</a> · <a href="/articletag/25013_new_0_1.html" class="aLightGray" title="DTO">DTO</a> · <a href="/articletag/39770_new_0_1.html" class="aLightGray" title="接口设计">接口设计</a> · <a href="javascript:;" class="aLightGray" title="php">php</a> <a href="javascript:;" class="aLightGray" title="参数校验">参数校验</a> <a href="javascript:;" class="aLightGray" title="统一错误响应">统一错误响应</a> <a href="javascript:;" class="aLightGray" title="Request DTO">Request DTO</a> <a href="javascript:;" class="aLightGray" title="接口迁移">接口迁移</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620114.html" class="aBlack" target="_blank" title="PHP 老接口迁移变更单:从散落 $_POST 到 Request DTO 与统一错误响应">PHP 老接口迁移变更单:从散落 $_POST 到 Request DTO 与统一错误响应</a> </dt> <dd class="cont2"> <span><i class="view"></i>199浏览</span> <span class="collectBtn user_collection" data-id="620114" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620103.html" class="img_box" title="PHP 表单提交后刷新重复提交怎么办:PRG 模式和闪存提示这样做"> <img src="/uploads/20260630/1782787294-php-prg-duplicate-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 表单提交后刷新重复提交怎么办:PRG 模式和闪存提示这样做"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  4天前  |   <a href="/articletag/1433_new_0_1.html" class="aLightGray" title="PHP">PHP</a> · <a href="/articletag/25404_new_0_1.html" class="aLightGray" title="PRG">PRG</a> · <a href="/articletag/39920_new_0_1.html" class="aLightGray" title="表单提交">表单提交</a> · <a href="/articletag/39990_new_0_1.html" class="aLightGray" title="重复提交">重复提交</a> · <a href="/articletag/39991_new_0_1.html" class="aLightGray" title="用户体验">用户体验</a> · <a href="javascript:;" class="aLightGray" title="用户体验">用户体验</a> <a href="javascript:;" class="aLightGray" title="重复提交">重复提交</a> <a href="javascript:;" class="aLightGray" title="PHP表单">PHP表单</a> <a href="javascript:;" class="aLightGray" title="PRG模式">PRG模式</a> <a href="javascript:;" class="aLightGray" title="闪存消息">闪存消息</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620103.html" class="aBlack" target="_blank" title="PHP 表单提交后刷新重复提交怎么办:PRG 模式和闪存提示这样做">PHP 表单提交后刷新重复提交怎么办:PRG 模式和闪存提示这样做</a> </dt> <dd class="cont2"> <span><i class="view"></i>232浏览</span> <span class="collectBtn user_collection" data-id="620103" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620099.html" class="img_box" title="PHP-FPM 慢请求报警运行手册:从 slowlog 到进程池参数调整"> <img src="/uploads/20260629/1782728272-php-fpm-runbook-fix.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP-FPM 慢请求报警运行手册:从 slowlog 到进程池参数调整"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  5天前  |   <a href="/articletag/1433_new_0_1.html" class="aLightGray" title="PHP">PHP</a> · <a href="/articletag/5276_new_0_1.html" class="aLightGray" title="php-fpm">php-fpm</a> · <a href="/articletag/39902_new_0_1.html" class="aLightGray" title="运维排查">运维排查</a> · <a href="/articletag/40062_new_0_1.html" class="aLightGray" title="慢请求">慢请求</a> · <a href="javascript:;" class="aLightGray" title="运维">运维</a> <a href="javascript:;" class="aLightGray" title="slowlog">slowlog</a> <a href="javascript:;" class="aLightGray" title="php-fpm">php-fpm</a> <a href="javascript:;" class="aLightGray" title="进程池">进程池</a> <a href="javascript:;" class="aLightGray" title="慢请求">慢请求</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620099.html" class="aBlack" target="_blank" title="PHP-FPM 慢请求报警运行手册:从 slowlog 到进程池参数调整">PHP-FPM 慢请求报警运行手册:从 slowlog 到进程池参数调整</a> </dt> <dd class="cont2"> <span><i class="view"></i>336浏览</span> <span class="collectBtn user_collection" data-id="620099" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620088.html" class="img_box" title="PHP 同步接口队列化改造趋势:从请求内处理到后台 Job Worker"> <img src="/uploads/20260629/1782713908-php-queue-adoption-path.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 同步接口队列化改造趋势:从请求内处理到后台 Job Worker"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  5天前  |   <a href="/articletag/220_new_0_1.html" class="aLightGray" title="Redis">Redis</a> · <a href="/articletag/39767_new_0_1.html" class="aLightGray" title="任务队列">任务队列</a> · <a href="/articletag/39782_new_0_1.html" class="aLightGray" title="php教程">php教程</a> · <a href="/articletag/39841_new_0_1.html" class="aLightGray" title="接口优化">接口优化</a> · <a href="/articletag/40038_new_0_1.html" class="aLightGray" title="后台任务">后台任务</a> · <a href="javascript:;" class="aLightGray" title="异步处理">异步处理</a> <a href="javascript:;" class="aLightGray" title="PHP队列">PHP队列</a> <a href="javascript:;" class="aLightGray" title="后台任务">后台任务</a> <a href="javascript:;" class="aLightGray" title="Redis队列">Redis队列</a> <a href="javascript:;" class="aLightGray" title="接口优化">接口优化</a> <a href="javascript:;" class="aLightGray" title="Job Worker">Job Worker</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620088.html" class="aBlack" target="_blank" title="PHP 同步接口队列化改造趋势:从请求内处理到后台 Job Worker">PHP 同步接口队列化改造趋势:从请求内处理到后台 Job Worker</a> </dt> <dd class="cont2"> <span><i class="view"></i>178浏览</span> <span class="collectBtn user_collection" data-id="620088" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620086.html" class="img_box" title="PHP 导出大数据内存耗尽排查:从一次性数组到流式写 CSV"> <img src="/uploads/20260629/1782711021-php-csv-memory-problem.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 导出大数据内存耗尽排查:从一次性数组到流式写 CSV"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  5天前  |   <a href="/articletag/39694_new_0_1.html" class="aLightGray" title="内存优化">内存优化</a> · <a href="/articletag/39782_new_0_1.html" class="aLightGray" title="php教程">php教程</a> · <a href="/articletag/39908_new_0_1.html" class="aLightGray" title="后端排查">后端排查</a> · <a href="/articletag/40035_new_0_1.html" class="aLightGray" title="CSV导出">CSV导出</a> · <a href="javascript:;" class="aLightGray" title="php">php</a> <a href="javascript:;" class="aLightGray" title="生成器">生成器</a> <a href="javascript:;" class="aLightGray" title="内存耗尽">内存耗尽</a> <a href="javascript:;" class="aLightGray" title="fputcsv">fputcsv</a> <a href="javascript:;" class="aLightGray" title="CSV导出">CSV导出</a> <a href="javascript:;" class="aLightGray" title="流式写入">流式写入</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620086.html" class="aBlack" target="_blank" title="PHP 导出大数据内存耗尽排查:从一次性数组到流式写 CSV">PHP 导出大数据内存耗尽排查:从一次性数组到流式写 CSV</a> </dt> <dd class="cont2"> <span><i class="view"></i>471浏览</span> <span class="collectBtn user_collection" data-id="620086" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620063.html" class="img_box" title="PHP 文件上传生命周期:从表单校验到存储和过期清理"> <img src="/uploads/20260627/1782562336-php-upload-lifecycle-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 文件上传生命周期:从表单校验到存储和过期清理"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  1星期前  |   <a href="/articletag/616_new_0_1.html" class="aLightGray" title="文件上传">文件上传</a> · <a href="/articletag/1364_new_0_1.html" class="aLightGray" title="安全">安全</a> · <a href="/articletag/1433_new_0_1.html" class="aLightGray" title="PHP">PHP</a> · <a href="/articletag/39745_new_0_1.html" class="aLightGray" title="后端开发">后端开发</a> · <a href="javascript:;" class="aLightGray" title="php">php</a> <a href="javascript:;" class="aLightGray" title="文件上传">文件上传</a> <a href="javascript:;" class="aLightGray" title="存储路径">存储路径</a> <a href="javascript:;" class="aLightGray" title="过期清理">过期清理</a> <a href="javascript:;" class="aLightGray" title="安全校验">安全校验</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620063.html" class="aBlack" target="_blank" title="PHP 文件上传生命周期:从表单校验到存储和过期清理">PHP 文件上传生命周期:从表单校验到存储和过期清理</a> </dt> <dd class="cont2"> <span><i class="view"></i>240浏览</span> <span class="collectBtn user_collection" data-id="620063" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620053.html" class="img_box" title="PHP 8.4 Property Hooks 实战:把 getter/setter 收回到属性声明里"> <img src="/uploads/20260627/1782549759-php84-property-hooks-migration-check.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 8.4 Property Hooks 实战:把 getter/setter 收回到属性声明里"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  1星期前  |   <a href="/articletag/1263_new_0_1.html" class="aLightGray" title="面向对象">面向对象</a> · <a href="/articletag/1433_new_0_1.html" class="aLightGray" title="PHP">PHP</a> · <a href="/articletag/39998_new_0_1.html" class="aLightGray" title="PHP8.4">PHP8.4</a> · <a href="/articletag/39999_new_0_1.html" class="aLightGray" title="Property Hooks">Property Hooks</a> · <a href="/articletag/40000_new_0_1.html" class="aLightGray" title="代码重构">代码重构</a> · <a href="javascript:;" class="aLightGray" title="PHP教程">PHP教程</a> <a href="javascript:;" class="aLightGray" title="Getter">Getter</a> <a href="javascript:;" class="aLightGray" title="PHP 8.4">PHP 8.4</a> <a href="javascript:;" class="aLightGray" title="Property Hooks">Property Hooks</a> <a href="javascript:;" class="aLightGray" title="setter">setter</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620053.html" class="aBlack" target="_blank" title="PHP 8.4 Property Hooks 实战:把 getter/setter 收回到属性声明里">PHP 8.4 Property Hooks 实战:把 getter/setter 收回到属性声明里</a> </dt> <dd class="cont2"> <span><i class="view"></i>464浏览</span> <span class="collectBtn user_collection" data-id="620053" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620051.html" class="img_box" title="PHP 文件上传后拿不到文件排查:从表单字段到 php.ini 限制"> <img src="/uploads/20260627/1782544110-php-upload-limit-path.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP 文件上传后拿不到文件排查:从表单字段到 php.ini 限制"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  1星期前  |   <a href="/articletag/616_new_0_1.html" class="aLightGray" title="文件上传">文件上传</a> · <a href="/articletag/39782_new_0_1.html" class="aLightGray" title="php教程">php教程</a> · <a href="/articletag/39867_new_0_1.html" class="aLightGray" title="问题排查">问题排查</a> · <a href="javascript:;" class="aLightGray" title="php">php</a> <a href="javascript:;" class="aLightGray" title="文件上传">文件上传</a> <a href="javascript:;" class="aLightGray" title="php.ini">php.ini</a> <a href="javascript:;" class="aLightGray" title="$_FILES">$_FILES</a> <a href="javascript:;" class="aLightGray" title="上传错误码">上传错误码</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620051.html" class="aBlack" target="_blank" title="PHP 文件上传后拿不到文件排查:从表单字段到 php.ini 限制">PHP 文件上传后拿不到文件排查:从表单字段到 php.ini 限制</a> </dt> <dd class="cont2"> <span><i class="view"></i>476浏览</span> <span class="collectBtn user_collection" data-id="620051" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620034.html" class="img_box" title="PHP Redis 缓存穿透和击穿防护工作流:从空值缓存到互斥锁"> <img src="/uploads/20260618/1781760203-php-redis-cache-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP Redis 缓存穿透和击穿防护工作流:从空值缓存到互斥锁"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  2星期前  |   <a href="/articletag/220_new_0_1.html" class="aLightGray" title="Redis">Redis</a> · <a href="/articletag/4232_new_0_1.html" class="aLightGray" title="缓存击穿">缓存击穿</a> · <a href="/articletag/5391_new_0_1.html" class="aLightGray" title="缓存穿透">缓存穿透</a> · <a href="/articletag/39782_new_0_1.html" class="aLightGray" title="php教程">php教程</a> · <a href="/articletag/39971_new_0_1.html" class="aLightGray" title="后端性能">后端性能</a> · <a href="javascript:;" class="aLightGray" title="php">php</a> <a href="javascript:;" class="aLightGray" title="redis">redis</a> <a href="javascript:;" class="aLightGray" title="互斥锁">互斥锁</a> <a href="javascript:;" class="aLightGray" title="缓存穿透">缓存穿透</a> <a href="javascript:;" class="aLightGray" title="TTL">TTL</a> <a href="javascript:;" class="aLightGray" title="缓存击穿">缓存击穿</a> <a href="javascript:;" class="aLightGray" title="空值缓存">空值缓存</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620034.html" class="aBlack" target="_blank" title="PHP Redis 缓存穿透和击穿防护工作流:从空值缓存到互斥锁">PHP Redis 缓存穿透和击穿防护工作流:从空值缓存到互斥锁</a> </dt> <dd class="cont2"> <span><i class="view"></i>229浏览</span> <span class="collectBtn user_collection" data-id="620034" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> <li> <div class="contBox"> <a href="/article/620032.html" class="img_box" title="PHP Session 登录态丢失排查工作流:从 Cookie 到 SameSite 和存储路径"> <img src="/uploads/20260618/1781757089-php-session-login-flow.webp" onerror="this.src='/assets/images/moren/morentu.png'" alt="PHP Session 登录态丢失排查工作流:从 Cookie 到 SameSite 和存储路径"> </a> <dl> <dd class="cont1"> <span> <a href="/articlelist/19_new_0_1.html" class="aLightGray" title="文章">文章</a> · <a href="/articlelist/84_new_0_1.html" class="aLightGray" title="php教程">php教程</a>   |  2星期前  |   <a href="/articletag/1200_new_0_1.html" class="aLightGray" title="Cookie">Cookie</a> · <a href="/articletag/4365_new_0_1.html" class="aLightGray" title="session">session</a> · <a href="/articletag/39782_new_0_1.html" class="aLightGray" title="php教程">php教程</a> · <a href="/articletag/39862_new_0_1.html" class="aLightGray" title="登录态">登录态</a> · <a href="/articletag/39908_new_0_1.html" class="aLightGray" title="后端排查">后端排查</a> · <a href="javascript:;" class="aLightGray" title="php">php</a> <a href="javascript:;" class="aLightGray" title="cookie">cookie</a> <a href="javascript:;" class="aLightGray" title="session">session</a> <a href="javascript:;" class="aLightGray" title="php-fpm">php-fpm</a> <a href="javascript:;" class="aLightGray" title="SameSite">SameSite</a> <a href="javascript:;" class="aLightGray" title="session_start">session_start</a> <a href="javascript:;" class="aLightGray" title="登录态丢失">登录态丢失</a> </span> </dd> <dt class="lineOverflow"> <a href="/article/620032.html" class="aBlack" target="_blank" title="PHP Session 登录态丢失排查工作流:从 Cookie 到 SameSite 和存储路径">PHP Session 登录态丢失排查工作流:从 Cookie 到 SameSite 和存储路径</a> </dt> <dd class="cont2"> <span><i class="view"></i>484浏览</span> <span class="collectBtn user_collection" data-id="620032" data-type="article" title="收藏"><i class="collect"></i>收藏</span> </dd> </dl> </div> </li> </ul> </div> </div> <div class="mainRight"> <!-- 右侧广告位banner --> <div class="rightContBox" style="margin-top: 0px;"> <div class="rightTit"> <a href="/courselist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">课程推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/course/9.html" class="img_box" target="_blank" title="前端进阶之JavaScript设计模式"> <img src="/uploads/20221222/52fd0f23a454c71029c2c72d206ed815.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="前端进阶之JavaScript设计模式"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/9.html" target="_blank" class="aBlack" title="前端进阶之JavaScript设计模式">前端进阶之JavaScript设计模式</a></dt> <dd class="cont1 lineTwoOverflow"> 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。 </dd> <dd class="cont2">543次学习</dd> </dl> </li> <li> <a href="/course/2.html" class="img_box" target="_blank" title="GO语言核心编程课程"> <img src="/uploads/20221221/634ad7404159bfefc6a54a564d437b5f.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="GO语言核心编程课程"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/2.html" target="_blank" class="aBlack" title="GO语言核心编程课程">GO语言核心编程课程</a></dt> <dd class="cont1 lineTwoOverflow"> 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。 </dd> <dd class="cont2">516次学习</dd> </dl> </li> <li> <a href="/course/74.html" class="img_box" target="_blank" title="简单聊聊mysql8与网络通信"> <img src="/uploads/20240103/bad35fe14edbd214bee16f88343ac57c.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="简单聊聊mysql8与网络通信"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/74.html" target="_blank" class="aBlack" title="简单聊聊mysql8与网络通信">简单聊聊mysql8与网络通信</a></dt> <dd class="cont1 lineTwoOverflow"> 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让 </dd> <dd class="cont2">500次学习</dd> </dl> </li> <li> <a href="/course/57.html" class="img_box" target="_blank" title="JavaScript正则表达式基础与实战"> <img src="/uploads/20221226/bbe4083bb3cb0dd135fb02c31c3785fb.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="JavaScript正则表达式基础与实战"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/57.html" target="_blank" class="aBlack" title="JavaScript正则表达式基础与实战">JavaScript正则表达式基础与实战</a></dt> <dd class="cont1 lineTwoOverflow"> 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。 </dd> <dd class="cont2">487次学习</dd> </dl> </li> <li> <a href="/course/28.html" class="img_box" target="_blank" title="从零制作响应式网站—Grid布局"> <img src="/uploads/20221223/ac110f88206daeab6c0cf38ebf5fe9ed.jpg" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="从零制作响应式网站—Grid布局"> </a> <dl> <dt class="lineTwoOverflow"><a href="/course/28.html" target="_blank" class="aBlack" title="从零制作响应式网站—Grid布局">从零制作响应式网站—Grid布局</a></dt> <dd class="cont1 lineTwoOverflow"> 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。 </dd> <dd class="cont2">485次学习</dd> </dl> </li> </ul> </div> <div class="rightContBox"> <div class="rightTit"> <a href="/ai.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">AI推荐</div> </div> <ul class="lessonRecomRList"> <li> <a href="/ai/13109.html" target="_blank" title="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" class="img_box"> <img src="/uploads/ai/20260616/ljg-skills-icon-8bbe1468e5.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="ljg-skills - "Prompt之神"李继刚开源的 AI 技能集" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13109.html" class="aBlack" target="_blank" title="ljg-skills">ljg-skills</a></dt> <dd class="cont1 lineTwoOverflow"> ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。 </dd> <dd class="cont2">3754次使用</dd> </dl> </li> <li> <a href="/ai/13108.html" target="_blank" title="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" class="img_box"> <img src="/uploads/ai/20260616/melo-icon-10bf590762.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="MELO音乐 - AI 音乐生成平台,支持多模态创作能力" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13108.html" class="aBlack" target="_blank" title="MELO音乐">MELO音乐</a></dt> <dd class="cont1 lineTwoOverflow"> MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款! </dd> <dd class="cont2">3466次使用</dd> </dl> </li> <li> <a href="/ai/13107.html" target="_blank" title="UniScribe - AI 免费在线音视频转文字平台" class="img_box"> <img src="/uploads/ai/20260616/uniscribe-icon-3c88366a15.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="UniScribe - AI 免费在线音视频转文字平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13107.html" class="aBlack" target="_blank" title="UniScribe">UniScribe</a></dt> <dd class="cont1 lineTwoOverflow"> UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。 </dd> <dd class="cont2">3435次使用</dd> </dl> </li> <li> <a href="/ai/13106.html" target="_blank" title="剧云 - 免费 AI 智能中文剧本创作平台" class="img_box"> <img src="/uploads/ai/20260615/d36c7176-icon-2b0cd581ce.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="剧云 - 免费 AI 智能中文剧本创作平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13106.html" class="aBlack" target="_blank" title="剧云">剧云</a></dt> <dd class="cont1 lineTwoOverflow"> 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。 </dd> <dd class="cont2">3618次使用</dd> </dl> </li> <li> <a href="/ai/13105.html" target="_blank" title="万象有声 - AI 一站式有声内容创作平台" class="img_box"> <img src="/uploads/ai/20260615/50267bac-icon-c146b001b5.png" onerror="this.onerror='',this.src='/assets/images/moren/morentu.png'" alt="万象有声 - AI 一站式有声内容创作平台" style="object-fit:cover;width:100%;height:100%;"> </a> <dl> <dt class="lineTwoOverflow"><a href="/ai/13105.html" class="aBlack" target="_blank" title="万象有声">万象有声</a></dt> <dd class="cont1 lineTwoOverflow"> 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单! </dd> <dd class="cont2">3592次使用</dd> </dl> </li> </ul> </div> <!-- 相关文章 --> <div class="rightContBox"> <div class="rightTit"> <a href="/articlelist.html" class="more" title="查看更多">查看更多<i class="iconfont"></i></a> <div class="tit lineOverflow">相关文章</div> </div> <ul class="aboutArticleRList"> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/616777.html" class="aBlack" title="宝塔配置Ruby环境:RVM+Nginx反代教程">宝塔配置Ruby环境:RVM+Nginx反代教程</a></dt> <dd> <span class="left">2026-05-29</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/616127.html" class="aBlack" title="unset函数作用范围详解">unset函数作用范围详解</a></dt> <dd> <span class="left">2026-05-29</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/598283.html" class="aBlack" title="VS Code配置Xdebug教程:PHP调试技巧全解析">VS Code配置Xdebug教程:PHP调试技巧全解析</a></dt> <dd> <span class="left">2026-05-13</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/591780.html" class="aBlack" title="PHPEnv安装PhpMyAdmin教程详解">PHPEnv安装PhpMyAdmin教程详解</a></dt> <dd> <span class="left">2026-05-07</span> <span class="right">501浏览</span> </dd> </dl> </li> <li> <dl> <dt class="lineTwoOverflow"><a href="/article/591040.html" class="aBlack" title="TelegramBotWebApp数据验证技巧">TelegramBotWebApp数据验证技巧</a></dt> <dd> <span class="left">2026-05-06</span> <span class="right">501浏览</span> </dd> </dl> </li> </ul> </div> </div> </div> <div class="footer"> <div class="footerIn"> <div class="footLeft"> <div class="linkBox"> <a href="/about/1.html" target="_blank" class="aBlack" title="关于我们">关于我们</a> <a href="/about/5.html" target="_blank" class="aBlack" title="免责声明">免责声明</a> <a href="#" class="aBlack" title="意见反馈">意见反馈</a> <a href="/about/2.html" class="aBlack" target="_blank" title="联系我们">联系我们</a> <a href="/send.html" class="aBlack" title="广告合作">内容提交</a> <a href="/manual/go/" target="_blank" class="aBlack" title="手册">手册</a> </div> <div class="footTip">Golang学习网:公益在线Go学习平台,帮助Go学习者快速成长!</div> <div class="shareBox"> <span><i class="qq"></i>技术交流群</span> </div> <div class="copyRight"> Copyright 2023 http://www.17golang.com/ All Rights Reserved | <a href="https://beian.miit.gov.cn/" target="_blank" title="备案">苏ICP备2023003363号-1</a> </div> </div> <div class="footRight"> <ul class="encodeList"> <li> <div class="encodeImg"> <img src="/assets/examples/qrcode_for_gh.jpg" alt="Golang学习网"> </div> <div class="tit">关注公众号</div> <div class="tip">Golang学习网</div> </li> <div class="clear"></div> </ul> </div> <div class="clear"></div> </div> </div> <!-- 微信登录弹窗 --> <style> .popupBg .n-error{ color: red; } </style> <div class="popupBg"> <div class="loginBoxBox"> <div class="imgbg"> <img src="/assets/images/leftlogo.jpg" alt=""> </div> <!-- 微信登录 --> <div class="loginInfo encodeLogin" style="display: none;"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.passwordLogin').show();"> <div class="tip">密码登录在这里</div> </div> <div class="encodeInfo"> <div class="tit"><i></i> 微信扫码登录或注册</div> <div class="encodeImg"> <span id="wx_login_qrcode"><img src="/assets/examples/code.png" alt="二维码"></span> <!-- <div class="refreshBox"> <p>二维码失效</p> <button type="button" class="create_wxqrcode">刷新1111</button> </div> --> </div> <div class="tip">打开微信扫一扫,快速登录/注册</div> </div> <div class="beforeLoginTip">登录即同意 <a href="#" class="aBlue" title="用户协议">用户协议</a> 和 <a href="#" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 密码登录 --> <div class="loginInfo passwordLogin"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="changeLoginType cursorPointer create_wxqrcode" onclick="$('.loginInfo').hide();$('.encodeLogin').show();"> <div class="tip">微信登录更方便</div> </div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem loginFormLi curr">密码登录</li> <li class="selfTabItem registerFormBox ">注册账号</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont loginFormBox" style="display: block;"> <form name="form" id="login-form" class="form-vertical form" method="POST" action="/index/user/login"> <input type="hidden" name="url" value="//17golang.com/article/604517.html"/> <input type="hidden" name="__token__" value="068b949e9e363d49db69719d6d189d24" /> <div class="form-group" style="height:70px;"> <input class="form-control" id="account" type="text" name="account" value="" data-rule="required" placeholder="邮箱/用户名" autocomplete="off"> </div> <div class="form-group" style="height:70px;"> <input class="form-control" id="password" type="password" name="password" data-rule="required;password" placeholder="密码" autocomplete="off"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="other"> <a href="#" class="forgetPwd aGray" onclick="$('.loginInfo').hide();$('.passwordForget').show();" title="忘记密码">忘记密码</a> </div> <div class="loginBtn mt25"> <button type="submit">登录</button> </div> </form> </div> <div class="selfTabCont registerFormBox" style="display: none;"> <form name="form1" id="register-form" class="form-vertical form" method="POST" action="/index/user/register"> <input type="hidden" name="invite_user_id" value="0"/> <input type="hidden" name="url" value="//17golang.com/article/604517.html"/> <input type="hidden" name="__token__" value="068b949e9e363d49db69719d6d189d24" /> <div class="form-group" style="height:70px;"> <input type="text" name="email" id="email2" data-rule="required;email" class="form-control" placeholder="邮箱"> </div> <div class="form-group" style="height:70px;"> <input type="text" id="username" name="username" data-rule="required;username" class="form-control" placeholder="用户名必须3-30个字符"> </div> <div class="form-group" style="height:70px;"> <input type="password" id="password2" name="password" data-rule="required;password" class="form-control" placeholder="密码必须6-30个字符"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" data-rule="required;length(4)" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <img src="/captcha.html" width="100" height="45" onclick="this.src = '/captcha.html?r=' + Math.random();"/> </span> </div> <div class="loginBtn"> <button type="submit">注册</button> </div> </form> </div> </div> </div> <div class="beforeLoginTip">登录即同意 <a href="https://www.17golang.com/about/3.html" target="_blank" class="aBlue" title="用户协议">用户协议</a> 和 <a href="https://www.17golang.com/about/4.html" target="_blank" class="aBlue" title="隐私政策">隐私政策</a></div> </div> <!-- 重置密码 --> <div class="loginInfo passwordForget"> <div class="closeIcon" onclick="$('.popupBg').hide();"></div> <div class="returnLogin cursorPointer" onclick="$('.passwordForget').hide();$('.passwordLogin').show();">返回登录</div> <div class="passwordInfo"> <ul class="logintabs selfTabMenu"> <li class="selfTabItem">重置密码</li> </ul> <div class="selfTabContBox"> <div class="selfTabCont"> <form id="resetpwd-form" class="form-horizontal form-layer nice-validator n-default n-bootstrap form" method="POST" action="/api/user/resetpwd.html" novalidate="novalidate"> <div style="height:70px;"> <input type="text" class="form-control" id="email" name="email" value="" placeholder="输入邮箱" aria-invalid="true"> </div> <div class="codeBox" style="height:70px;"> <div class="form-group" style="height:70px; width:205px; float: left;"> <input type="text" name="captcha" class="form-control" placeholder="验证码" /> </div> <span class="input-group-btn" style="padding:0;border:none;"> <a href="javascript:;" class="btn btn-primary btn-captcha cursorPointer" style="background: #2080F8; border-radius: 4px; color: #fff; padding: 12px; position: absolute;" data-url="/api/ems/send.html" data-type="email" data-event="resetpwd">发送验证码</a> </span> </div> <input type="password" class="form-control" id="newpassword" name="newpassword" value="" placeholder="请输入6-18位密码"> <div class="loginBtn mt25"> <button type="submit">重置密码</button> </div> </form> </div> </div> </div> </div> </div> </div> <script src="/assets/js/juejin-theme.js?v=20260613b" defer></script> <script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?3dc5666f6478c7bf39cd5c91e597423d"; hm.async = true; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script> <script src="/assets/js/frontend/common.js"></script> </body> </html>