我有一个简单的Cherrypy脚本,现在只提供一个页面。我希望页面能够动态显示图像。为此我写了一个简单的JS脚本。但是,当我尝试运行该页面时,它无法找到该图像。代码从~/image_player/test_app.py
运行,图片位于~/image_player/app/public
。请参阅静态路径的python代码:
import cherrypy
import os
import sys
class image_player(object):
@cherrypy.expose
def index(self):
return open('app/index.html')
if __name__ == '__main__':
if len(sys.argv) == 2:
port = int(sys.argv[1])
else:
port = 3030
host = '0.0.0.0'
conf = {
'/': {
'tools.sessions.on': True,
'tools.staticdir.root': os.path.abspath(os.getcwd())
},
'/query': {
'request.dispatch': cherrypy.dispatch.MethodDispatcher(),
'tools.response_headers.on': True,
'tools.response_headers.headers': [('Content-Type', 'text/plain')],
},
'/static': {
'tools.staticdir.on': True,
'tools.staticdir.dir': 'app/public'
},
'/js': {
'tools.staticdir.on': True,
'tools.staticdir.dir': 'app/js'
}
}
webapp = image_player()
# Configure server and port
cherrypy.config.update({'server.socket_host': host,
'server.socket_port': port})
cherrypy.quickstart(webapp, '/', conf)
这是包含js的index.html
:
<!DOCTYPE html>
<html>
<head>
<link href="/static/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
hello
<div id="imageDiv"></div>
<script>
var par = document.getElementById('imageDiv');
var img = document.createElement('img');
img.src = '/LPROFILE.jpg';
par.appendChild(img);
</script>
</body>
</html>
我得到的错误是GET http://hostname/LPROFILE.jpg 404 (Not Found)
我在这里显然遗漏了一些简单的东西,但我不确定是什么。
答案 0 :(得分:2)
根据您显示的配置,静态文件在/static
路径下提供,这意味着app/public
下的所有文件(相对于启动服务器的初始目录)都在运行可以从http://hostname/static/
访问,LPROFILE.jpg
,http://hostname/static/LPROFILE.jpg
答案 1 :(得分:0)
它对我有用(赢得x64):
$currentCount=0;
$currentSeconds;
function callAPI()
{
if($currentCount<8 || date("s") != $currentSeconds)
{
if(date("s") != $currentSeconds)
{
$currentCount=0;
}
$currentSeconds=date("s");
//call your API here
$currentCount++;
}
}
例如: url(../ img / backgr.jpg)