如果还没有手动打开,python3 django无法将imgur图像加载到html

问题描述 投票:0回答:1

我正在研究一个项目我python3 Django,它将测试你在斯洛伐克的道路标志的知识。当我在Imgur上存储所有300个标志图像时出现问题。如果我首先打开带有标志的图像而不是我的HTML页面内的图像,一切都很好,但我需要生成随机图像,所以我不知道哪一个将是下一个。谷歌浏览器控制台给我403错误代码'禁止'我也可以在开发人员工具的网络选项卡中看到它加载图像为txt/plain,这似乎是我可疑的。

你能以某种方式帮助我吗?

这是我的HTML

{% load static %}
<link rel="stylesheet" type="text/css" href="{% static 

'app_signs/style.css' %}">
</head>
<body class="question">
  <form action="/question" method = "post">{% csrf_token %}
    <div class="container">
      <br>
      <img src="{{ right_sign.signurl }}" class="main_sign" alt="FOTKA">
      <br>
      <h3>Aka je to znacka?</h3>
      {% for sign in list%}
        <p>{{ sign }}<p>
      {% endfor %}
    </div>
  </form>
</body>

这是views.py

from django.http import HttpResponse
from django.template import loader
from django.views.decorators.http import require_http_methods
from django.shortcuts import redirect

from app_signs.models import sign

import random


@require_http_methods(["GET", "POST"])
def question(request):
    if request.method == 'GET':
        rndint1 = '{:03}'.format(random.randint(1, 386))
        rndint2 = '{:03}'.format(random.randint(1, 386))
        rndint3 = '{:03}'.format(random.randint(1, 386))
        rndint4 = '{:03}'.format(random.randint(1, 386))

        right_sign = sign.objects.get(sign_id=rndint1)
        fake_sign1 = sign.objects.get(sign_id=rndint2)
        fake_sign2 = sign.objects.get(sign_id=rndint3)
        fake_sign3 = sign.objects.get(sign_id=rndint4)

        list_sign = [right_sign.sign_name,
                     fake_sign1.sign_name,
                     fake_sign2.sign_name,
                     fake_sign3.sign_name]

        random.shuffle(list_sign, random.random)

        template = loader.get_template('app_signs/question.html')
        return HttpResponse(template.render({'right_sign': right_sign,
                                             'list': list_sign}, request))

这是模特

from django.db import models


class sign(models.Model):
    sign_category = models.CharField(max_length=250)
    sign_id = models.CharField(max_length=4)
    sign_name = models.CharField(max_length=250)
    sign_url = models.CharField(max_length=250)

    def __str__(self):
            return self.sign_name
python django python-3.x security imgur
1个回答
0
投票

我终于找到了解决方案,它与python代码没有任何关系。 Trick正在将127.0.0.1改为localhost

© www.soinside.com 2019 - 2024. All rights reserved.