服务器配置篇 ━━ IIS7使用https上传发生413错误,响应提示:未显示页面,因为请求实体过大

本文主要是介绍服务器配置篇 ━━ IIS7使用https上传发生413错误,响应提示:未显示页面,因为请求实体过大,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用windows自建证书搭建网站,本地127.0.0.1上传正常,但外网上传仅限几十K的文件,若超出大小则提示:
错误:413;响应:“未显示页面,因为请求实体过大。

一度以为是防火墙的问题,排查未果。今终于解决问题,整理如下:

一、原理

官方说明:Client cannot renegotiate request and returns an HTTP 413 error

  • 如果 Web 服务器、网站或站点的单个目录或文件上启用了客户端证书,则客户端在上载较大的文件时可能会看到 HTTP 413 错误。

  • 如果客户端向运行 IIS 6.0(7.0) 的 Web 服务器发送一个较长的 HTTP 请求(如 POST 请求),则 IIS 工作进程可能会收到足以解析请求标头的数据,但不会收到整个请求实体正文。当 IIS 工作进程检测到需要客户端证书以向客户端返回数据时,IIS 尝试重新协商客户端连接。不过,客户端无法重新协商连接,因为它正在等待向 IIS 发送请求中的其余数据。

  • 如果请求客户端重新协商,则必须使用 SSL 预加载功能预加载请求实体正文。SSL 预加载功能将使用用于 ISAPI 扩展的 UploadReadAheadSize 配置数据库属性的值。但是,如果 UploadReadAheadSize 小于内容长度,则返回 HTTP 413 错误,并关闭连接以防止出现死锁。(在以下情况下出现“死锁”:客户端正在等待发送请求实体,而服务器等待完成重新协商,重新协商要求客户端能够发送数据,可是这是无法完成的。)

  • 解决方案是确保没有禁止客户端发送整个实体正文。为此,应将 UploadReadAheadSize 的值更改为大于内容长度的值和最大请求实体主体限制更改为大于文件大小。

在这里插入图片描述

二、解决方案

1. 配置UploadReadAheadSize 【关键】

官方解决方案:IIS7 Tweet #1 : Setting UploadReadAheadSize

  • 使用 Appcmd.exe 命令来修改限制,Appcmd.exe 位于 %WinDir%\System32\Inetsrv
appcmd.exe set config  -section:system.webServer/serverRuntime /uploadReadAheadSize:"49152"  /commit:apphost
  • uploadReadAheadSize 的值逐渐改大来做测试,比如可以98304 -> 196608 -> 393216 -> 20480000
    在这里插入图片描述

2. 配置MaxRequestEntityAllowed

  • 在IIS 功能视图 中双击 ASP 模块,打开 限制属性 ,将最后一项 最大请求实体主体限制[maxRequestEntityAllowed] 改为你需要的值(例如 1073741824, 1GB)。
  • 同时,请注意如果你上传的文件较大,请考虑 脚本超时[scriptTimeOut] 是否需要更改, 默认是00:01:30,可改成了00:05:30。

在这里插入图片描述

3.修改开发语言自身的限制

比如php,在php.ini中重新配置上传限制,因与本文关系不大,各种开发语言的上传限制不再赘述。

max_execution_time = 300
max_input_time = 600
post_max_size = 8M
upload_max_filesize = 50M
max_file_uploads = 20

4.配置maxAllowedContentLength

项目主目录web.config文件,参考以下内容,增加maxAllowedContentLength

<?xml version="1.0" encoding="UTF-8"?><configuration><system.webServer><security><requestFiltering><requestLimits maxAllowedContentLength="1048576000" /></requestFiltering></security><handlers><add name="Python FastCGI" path="*" verb="*" modules="FastCgiModule" scriptProcessor="C:\Users\Administrator\.virtualenvs\Python-LxgTLIVq\Scripts\python.exe|E:\Python\wfastcgi.py" resourceType="Unspecified" requireAccess="Script" /></handlers></system.webServer><appSettings><add key="WSGI_HANDLER" value="django.core.wsgi.get_wsgi_application()" /><add key="PYTHONPATH" value="E:\Python" /><add key="DJANGO_SETTINGS_MODULE" value="workjob.settings" /></appSettings></configuration>

maxAllowedContentLength=“1048576000” ,将最大允许内容长度配置为1000M。

5. 上传超时

大文件上传时间可能超过既定值,导致报错:“HTTP 错误 500.0 - Internal Server Error”FastCGI 进程超过了配置的请求超时时限。
在这里插入图片描述

参考以下修改时间
在这里插入图片描述
重启IIS

三、参考

  1. 安全篇 ━━ windows2008自建证书、IIS配置https服务器及浏览器报错处理
  2. 关于如何设置IIS7的配置,请参考 Configuration Reference <configuration>
  3. IIS7 https 发生413错误 未显示页面,因为请求实体过大
  4. Django + iis 上传文件时发生未显示页面,因为请求实体过大
  5. 小程序上传附件问题:未显示页面,因为请求实体过大
  6. 前端大文件上传方法(深度好文)

这篇关于服务器配置篇 ━━ IIS7使用https上传发生413错误,响应提示:未显示页面,因为请求实体过大的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/606532

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

使用python生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

win10安装及配置Gradle全过程

《win10安装及配置Gradle全过程》本文详细介绍了Gradle的下载、安装、环境变量配置以及如何修改本地仓库位置,通过这些步骤,用户可以成功安装并配置Gradle,以便进行项目构建... 目录一、Gradle下载1.1、Gradle下载地址1.2、Gradle下载步骤二、Gradle安装步骤2.1、安

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置