Cherrypy和JS,找不到图片

时间:2017-04-24 17:04:50

标签: javascript python cherrypy

我有一个简单的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)我在这里显然遗漏了一些简单的东西,但我不确定是什么。

2 个答案:

答案 0 :(得分:2)

根据您显示的配置,静态文件在/static路径下提供,这意味着app/public下的所有文件(相对于启动服务器的初始目录)都在运行可以从http://hostname/static/访问,LPROFILE.jpghttp://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)