いわゆる static リソースとは、images、js、css およびその他のファイルを指します。公式の指示はここにあります。
小さなプロジェクトを例に挙げて説明しますは、プロジェクトのディレクトリ構造です:
. ├── static │ ├── css │ │ ├── base.css │ │ ├── bootstrap.min.css │ │ └── font-awesome.min.css │ ├── font │ │ ├── FontAwesome.otf │ │ ├── fontawesome-webfont.eot │ │ ├── fontawesome-webfont.svg │ │ ├── fontawesome-webfont.ttf │ │ └── fontawesome-webfont.woff │ └── index.html └── proxy_server.py
proxy_server.py
に、2 つの静的ファイル ディレクトリ static/css
を指定します。 > と static/font
ルーティングを追加します proxy_server.py
给2个静态文件目录static/css
和static/font
添加路由:
app.router.add_static('/css/', path='static/css', name='css') app.router.add_static('/font/', path='static/font', name='font')
先来看看add_static
方法的定义:
def add_static(self, prefix, path, *, name=None, expect_handler=None, chunk_size=256*1024, response_factory=StreamResponse, show_index=False, follow_symlinks=False): """Add static files view. prefix - url prefix path - folder with files """ # TODO: implement via PrefixedResource, not ResourceAdapter assert prefix.startswith('/') if prefix.endswith('/'): prefix = prefix[:-1] resource = StaticResource(prefix, path, name=name, expect_handler=expect_handler, chunk_size=chunk_size, response_factory=response_factory, show_index=show_index, follow_symlinks=follow_symlinks) self.register_resource(resource) return resource
必需的2个参数:prefix
:是静态文件的url
的前缀,以/
开始,在浏览器地址栏上显示在网站host之后,也用于index.html
静态页面进行引用path
:静态文件目录的路径,可以是相对路径,上面代码使用的static/css
就是相对路径——相对于proxy_server.py
所在路径。
下面是页面的效果:
加载的是index.html
,下面是它引用静态资源的代码:
<!-- Bootstrap CSS --> <link href="css/bootstrap.min.css" rel="stylesheet"> <!-- Base CSS --> <link href="css/base.css" rel="stylesheet"> <!-- FA CSS --> <link href="css/font-awesome.min.css" rel="stylesheet">
添加font
的路径是因为/font-awesome.min.css
需要使用:
在浏览器中打开css文件:
可以看到是url的前缀是/css/
。
如果修改前缀:
app.router.add_static('/css2017/', path='static/css', name='css')
页面变成了:
css文件也无法访问了:
修改index.html
中的css的引用路径:
<!-- Bootstrap CSS --> <link href="css2017/bootstrap.min.css" rel="stylesheet"> <!-- Base CSS --> <link href="css2017/base.css" rel="stylesheet"> <!-- FA CSS --> <link href="css2017/font-awesome.min.css" rel="stylesheet">
虽然目录本身还是css
,但通过add_static
已经将它视为了css2017
,页面回复正常了:
css文件也可以打开了:
url前缀变成了/css2017/
了。
此时直接打开index.html
文件就会显示为
因为static
目录下并没有css2017
这个文件夹。
至此就了解了add_static
的基本使用方法了,可以通过重新定义prefix
参数还可以隐藏服务器上真实的存放静态资源的目录,也可以将分散在各处的资源文件统一到同一个路径前缀下。
此外,如果加上 必須の 2 つのパラメータ: show_index=True
: app.router.add_static('/css2017/',
path='static/css',
name='css',
show_index=True)
add_static
メソッド定義: rrreeeprefix
: 静的ファイルの url
のプレフィックスです。 /
Start。ブラウザのアドレス バーの Web サイト ホストの後に表示されます。引用path
: 静的ファイル ディレクトリへのパス。相対パスにすることができます。static/css上記のコードで使用されている code> は相対パスです。<code>proxy_server.py
が配置されているパスを基準としています。 🎜このページの効果は次のとおりです: 🎜🎜読み込まれるのはindex.html
で、以下のコードです静的リソースを参照する: 🎜 rrreee🎜 /font-awesome.min.css
で使用する必要があるため、font
のパスを追加します: 🎜🎜ブラウザで CSS ファイルを開きます: 🎜🎜URLのプレフィックスが/であることがわかります。 css/
。 🎜接頭辞を変更すると: 🎜rrreee🎜ページは次のようになります: 🎜🎜css ファイルにもアクセスできません: 🎜🎜 index.html
内の css の参照パスを変更します: 🎜rrreee🎜 ディレクトリ自体は css
のままですが、add_static
を通じて> code>css2017
とみなされ、ページは通常に戻ります: 🎜🎜css ファイルも使用できます。開いた: 🎜🎜URL プレフィックスが /css2017/
になりました。 🎜この時点で index.html
ファイルを直接開くと、🎜🎜static ディレクトリ <code>css2017
フォルダーがありません。 🎜🎜これで、add_static
の prefix
パラメータを再定義することで、サーバー上で静的リソースが格納されている実際のディレクトリを非表示にしたり、あちこちに散在するリソース ファイルを同じパス プレフィックスの下に統合したりできます。 🎜🎜さらに、show_index=True
を追加すると、静的リソース ディレクトリ 🎜index🎜 を表示できます - デフォルトではアクセスが禁止されています: 🎜rrreee🎜🎜🎜
以上がaiohttp の静的リソース パスの追加方法についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。