【求大神】访问任意文件url返回任意文件名给用户下载??????
访问任意文件url返回任意文件名给用户下载??????
案例:
http://down1.020pidai.com/8935/服务器里面其实只有一个文件..
如000000.exe
要现实的功能是:
用户访问任意名称就可以下载任意名称的文件 , 而不会出现404错位文件不存在的情况
访问
http://down1.020pidai.com/8935/111111.exe
服务器返回111111.exe给用户下载,用户下载看到的文件名为111111.exe而不是服务器上的000000.exe
http://down1.020pidai.com/8935/222222.exe
服务器返回222222.exe给用户下载,,用户下载看到的文件名为222222.exe而不是服务器上的000000.exe
麻烦大神
回复讨论(解决方案)
就是不管用户输什么名字,都只下载000000.exe这个文件?
header("Content-Disposition: attachment; filename=000000.exe");
就是不管用户输什么名字,都只下载000000.exe这个文件?
header("Content-Disposition: attachment; filename=000000.exe");
你的代码是访问任何url下载000000.exe 但接收的文件名是000000.exe
就是不管用户输什么名字,都只下载000000.exe这个文件?
header("Content-Disposition: attachment; filename=000000.exe");
我要的效果是 服务器只有000000.exe 一个文件
用户访问 www.url.com/down/111111.exe 会保存111111.exe而不是保存000000.exe
用户访问 www.url.com/down/222222.exe 会保存222222.exe而不是保存000000.exe
用 urlrewrite 隐去入口文件名
于是 http://down1.020pidai.com/8935/222222.exe 中的 /8935/222222.exe 就作为 PATH_INFO 传入入口文件
而 /8935/222222.exe 中的
8935 就可代表实际的 000000.exe
222222.exe 就是 header("Content-Disposition: attachment; filename=$filename"); $filename
能够理解吗?
用 urlrewrite 隐去入口文件名
于是 http://down1.020pidai.com/8935/222222.exe 中的 /8935/222222.exe 就作为 PATH_INFO 传入入口文件
而 /8935/222222.exe 中的
8935 就可代表实际的 000000.exe
222222.exe 就是 header("Content-Disposition: attachment; filename=$filename"); $filename
能够理解吗?
代码这样写???貌似代码没提及到去下载000000.exe
header("Content-Disposition: attachment; filename=$filename"); $filename
?>
还有怎么访问这个呢? 以上代码保存为exe.php放在根目录www.url.com/exe.php
www.url.com/down/***
伪静态重写www.url.com/exe.php ???
是否这样??
已明白!!
全部代码
新建exe.php
代码:
header("Content-Disposition: attachment; filename=$filename"); $filename
?>
新建.htaccess文件
代码:
RewriteEngine On
RewriteBase /
RewriteRule ^index\.php$ ? [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
新建目录8935
目录8935下新建.htaccess文件
代码如下:
RewriteEngine On
RewriteBase /8935/
RewriteRule ^000000\.exe$ ? [L]
RewriteRule . /000000.exe [L]
在目录8935下放000000.exe即可
这样就达到访问www.url.com/8935/随意写名字.exe
得到的文件为:
随意写名字.exe
apache可以了iis的httpd.ini 怎么弄呢,可以实现不
用 urlrewrite 隐去入口文件名
于是 http://down1.020pidai.com/8935/222222.exe 中的 /8935/222222.exe 就作为 PATH_INFO 传入入口文件
而 /8935/222222.exe 中的
8935 就可代表实际的 000000.exe
222222.exe 就是 header("Content-Disposition: attachment; filename=$filename"); $filename
能够理解吗?
版主iis可以实现这样的效果吗,httpd.ini里面

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Alipay PHP ...

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Die Hijacking der Sitzung kann in den folgenden Schritten erreicht werden: 1. Erhalten Sie die Sitzungs -ID, 2. Verwenden Sie die Sitzungs -ID, 3. Halten Sie die Sitzung aktiv. Zu den Methoden zur Verhinderung der Sitzung der Sitzung in PHP gehören: 1. Verwenden Sie die Funktion Session_regenerate_id (), um die Sitzungs -ID zu regenerieren. 2. Store -Sitzungsdaten über die Datenbank, 3. Stellen Sie sicher, dass alle Sitzungsdaten über HTTPS übertragen werden.

Die Anwendung des soliden Prinzips in der PHP -Entwicklung umfasst: 1. Prinzip der Einzelverantwortung (SRP): Jede Klasse ist nur für eine Funktion verantwortlich. 2. Open and Close Principle (OCP): Änderungen werden eher durch Erweiterung als durch Modifikation erreicht. 3.. Lischs Substitutionsprinzip (LSP): Unterklassen können Basisklassen ersetzen, ohne die Programmgenauigkeit zu beeinträchtigen. 4. Schnittstellen-Isolationsprinzip (ISP): Verwenden Sie feinkörnige Schnittstellen, um Abhängigkeiten und nicht verwendete Methoden zu vermeiden. 5. Abhängigkeitsinversionsprinzip (DIP): Hoch- und niedrige Module beruhen auf der Abstraktion und werden durch Abhängigkeitsinjektion implementiert.

So setzen Sie die Berechtigungen von Unixsocket automatisch nach dem Neustart des Systems. Jedes Mal, wenn das System neu startet, müssen wir den folgenden Befehl ausführen, um die Berechtigungen von Unixsocket: sudo ...

Wie debugge ich den CLI -Modus in PhpStorm? Bei der Entwicklung mit PHPSTORM müssen wir manchmal den PHP im CLI -Modus (COMS -Zeilenschnittstellen) debuggen ...

Statische Bindung (statisch: :) implementiert die späte statische Bindung (LSB) in PHP, sodass das Aufrufen von Klassen in statischen Kontexten anstatt Klassen zu definieren. 1) Der Analyseprozess wird zur Laufzeit durchgeführt.

Senden von JSON -Daten mithilfe der Curl -Bibliothek von PHP in der PHP -Entwicklung müssen häufig mit externen APIs interagieren. Eine der gängigen Möglichkeiten besteht darin, die Curl Library zu verwenden, um Post � ...
