Служить статическому файлу с помощью App Engine
Я создал приложение App Engine. До сих пор у меня есть только несколько файлов HTML для обслуживания. Что я могу сделать, чтобы App Engine обслуживал файл index.html при каждом посещении http://example.appengine.com/?
В настоящее время мой файл app.yaml выглядит так:
application: appname
version: 1
runtime: python
api_version: 1
handlers:
- url: /
static_dir: static_files
5 ответов
Это должно сделать то, что вам нужно:
https://gist.github.com/873098
Объяснение: В App Engine Python можно использовать регулярные выражения в качестве обработчиков URL в app.yaml
и перенаправить все URL-адреса в иерархию статических файлов.
пример app.yaml
:
application: your-app-name-here
version: 1
runtime: python
api_version: 1
handlers:
- url: /(.*\.css)
mime_type: text/css
static_files: static/\1
upload: static/(.*\.css)
- url: /(.*\.html)
mime_type: text/html
static_files: static/\1
upload: static/(.*\.html)
- url: /(.*\.js)
mime_type: text/javascript
static_files: static/\1
upload: static/(.*\.js)
- url: /(.*\.txt)
mime_type: text/plain
static_files: static/\1
upload: static/(.*\.txt)
- url: /(.*\.xml)
mime_type: application/xml
static_files: static/\1
upload: static/(.*\.xml)
# image files
- url: /(.*\.(bmp|gif|ico|jpeg|jpg|png))
static_files: static/\1
upload: static/(.*\.(bmp|gif|ico|jpeg|jpg|png))
# index files
- url: /(.+)/
static_files: static/\1/index.html
upload: static/(.+)/index.html
# redirect to 'url + /index.html' url.
- url: /(.+)
static_files: static/redirector.html
upload: static/redirector.html
# site root
- url: /
static_files: static/index.html
upload: static/index.html
Для обработки запросов к URL, которые не заканчиваются распознанным типом (.html
, .png
и т. д.) или /
вам нужно перенаправить эти запросы URL + /
Итак index.html
для этого каталога подается. Я не знаю, как сделать это внутри app.yaml
, поэтому я добавил редиректор JavaScript. Это также можно сделать с помощью крошечного обработчика Python.
redirector.html
:
<!DOCTYPE html>
<html lang="en">
<head>
<script language="JavaScript">
self.location=self.location + "/";
</script>
</head>
<body>
</body>
</html>
Это можно сделать с помощью (app.yaml):
handlers:
- url: /appurl
script: myapp.app
- url: /(.+)
static_files: staticdir/\1
upload: staticdir/(.*)
- url: /
static_files: staticdir/index.html
upload: staticdir/index.html
Если вы пытаетесь отобразить /
в index.html
:
handlers:
- url: /
upload: folderpath/index.html
static_files: folderpath/index.html
url:
будет соответствовать пути и поддерживает регулярные выражения.
- url: /images
static_dir: static_files/images
Так что, если ваш файл изображения хранится в static_files/images/picture.jpg
использовать этот:
<img src="/images/picture.jpg" />
Вот app.yaml о том, как я запустил сайт, сгенерированный Jekyll:
runtime: python27
api_version: 1
threadsafe: true
handlers:
- url: /
static_files: _site/index.html
upload: _site/index.html
- url: /assets
static_dir: _site/assets
# index files
- url: /(.+)/
static_files: _site/\1/index.html
upload: _site/(.+)/index.html
- url: /(.*)
static_files: _site/\1
upload: _site/(.*)
- url: /.*
static_dir: _site
В WEB-INF/web.xml поместите:
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>