dou5454954610 2015-01-19 10:58
浏览 20
已采纳

将htaccess传递给PHP文件

I want to create system, that will check file before it proceed to user.

This is my main line in .htaccess file:

RewriteRule ^([^\.]+)$ ./getfile.php?hash=$1 [L,QSA]

This is in getfile.php file:

print_r($_GET['hash']);

Both of these files are in separated folder named get.

So, when I try this URL:

http://localhost/example/get/information

Then it prints information - that's what I was expecting.

But, when I try this URL (there could be more information files):

http://localhost/example/get/information.txt

This prints Error 404. My files are stored in secured folder, so there is no dirrect access to any file. For example, only logged in users will be able to download these files.

So, how can I edit any file, so $_GET['hash'] will contains information.txt?

PS: Don't suggest me better ways, I want it this way.

  • 写回答

1条回答 默认 最新

  • drygauost253590142 2015-01-19 11:05
    关注

    You can replace your rule with:

    # If the request is not for a valid directory
    RewriteCond %{REQUEST_FILENAME} !-d
    # If the request is not for a valid file
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteRule ^([^/]+)/?$ getfile.php?hash=$1 [L,QSA]
    

    Your regex [^/.]+ is only grabbing text before a DOT.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?