【问题标题】:Django media upload not working when uploading image through code通过代码上传图像时,Django媒体上传不起作用
【发布时间】:2019-07-21 07:04:49
【问题描述】:

我创建了一个 Django 应用程序,其中有一个注册页面,要求用户上传他们的个人资料图片。 当我通过 Django 管理面板上传个人资料图片时,图像被上传到正确的路径并显示在网站中。但是,当我在注册时直接选择要上传的图像时出现错误,然后当我在 Django admin 中单击上传的图像时,它显示找不到页面并且图像的路径显示为 C:\Users\hp\工作区\findem\media\image.jpg

Settings.py

STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
STATICFILES_DIRS = [
 os.path.join(BASE_DIR, 'findem/static')
]

# media folder settings
MEDIA_ROOT = os.path.join(BASE_DIR , 'media').replace('\\', '/')
MEDIA_URL = '/media/'

用户模型

class UserProfile(AbstractBaseUser, PermissionsMixin):
    """Represents a user profile inside our system"""

    email = models.EmailField(max_length=255, unique=True)
    name = models.CharField(max_length=255, default=profile_pic)
    profile_picture = models.ImageField(upload_to='photos/profile_pictures/', default='photos/User.jpg')
    is_active = models.BooleanField(default=True)
    is_staff = models.BooleanField(default=False)
    highest_degree_earned = models.CharField(max_length=255, blank=False)
    college_name = models.CharField(max_length=255, blank=False)
    graduation_year = models.IntegerField(default=2020, blank=False)

模板:

   <form class="needs-validation" novalidate autocomplete="off" 
action="{% url 'signup' %}", method="POST" >
{% csrf_token %}
<div id="Personal_Information">
<h5 class="loginSignup">Personal Information</h5>

   <div class="form-group row">
    <label for="inputprofile" class="col-sm-2 col-form-label">Profile Picture</label>
    <div class="col-sm-5">
      <div class="input-group">
      <div class="custom-file">
       <input type="file" accept="image/png, image/jpeg, image/gif" class="custom-file-input" id="inputprofile" name="inputprofile">
       <label class="custom-file-label" for="inputprofile" aria-describedby="inputprofile">Choose file</label>
      </div>
     </div>
   </div>
  </div>

  <div class="form-group required row">
    <label for="inputname" class="col-sm-2 col-form-label">Full Name <span id="required-field">*
     </span>
    </label>

   <div class="col-sm-5">
     <input type="text" class="form-control" name="inputname" id="inputname" placeholder="Enter Your Full Name" required>
     <div class="valid-feedback">Looks good!</div>
     <div class="invalid-feedback">Please enter your full name.</div>
    </div>

  </div>

  <div class="form-group row">
    <label for="inputemal" class="col-sm-2 col-form-label">Email <span id="required-field">*</span></label>
     <div class="col-sm-5">
       <input type="email" class="form-control" id="inputEmail" name="inputEmail" placeholder="Enter a Valid Email Address" required>
       <div class="valid-feedback">Looks good!</div>
       <div class="invalid-feedback">Please provide a valid email.</div>
    </div>
  </div>

<div class="form-group row">
    <label for="inputPassword" class="col-sm-2 col-form-label">Password <span id="required-field">*</span></label>
     <div class="col-sm-5">
       <input type="password" class="form-control" id="inputPassword" name="inputPassword" placeholder="Choose a Password" required>
       <div class="valid-feedback">Looks good!</div>
       <div class="invalid-feedback">Please chose a valid password.</div>
    </div>
  </div>

  <button type="submit" class="btn btn-success mt-3" id="loginButton">Sign Up</button>
</form>

查看:

def signup(request):
"""View for Signing-up into the system"""
if request.method == 'POST':

    # Get form value
    profile_picture = request.POST.get('inputprofile')
    name = request.POST.get('inputname')
    email = request.POST['inputEmail']
    password = request.POST['inputPassword']
    highest_degree_earned = request.POST['inputDegree']
    college_name = request.POST['CollegeName']
    graduation_year = request.POST['inputGradYear']
    skill_1 = request.POST['upload_skill1']
    skill_2 = request.POST.get('upload_skill2', '')
    skill_3 = request.POST.get('upload_skill3', '')
    skill_4 = request.POST.get('upload_skill4', '')
    skill_5 = request.POST.get('upload_skill5', '')
    skill_6 = request.POST.get('upload_skill6', '')
    join_date = datetime.now()


    # Check Username
    if UserProfile.objects.filter(name=name).exists():
        messages.error(request, "That Name already taken")
        return redirect('signup')
    # Check email
    else:
        if UserProfile.objects.filter(email=email).exists():
            messages.error(request, "That email is being used")
            return redirect('signup')
        else:
            # Looks Good
            user = UserProfile.objects.create_user(profile_picture=profile_picture, name=name, email=email, 
            password=password, highest_degree_earned=highest_degree_earned, college_name=college_name, 
            graduation_year=graduation_year, skill_1=skill_1, skill_2=skill_2, skill_3=skill_3, skill_4=skill_4,
            skill_5=skill_5, skill_6=skill_6, join_date=join_date)

            # #Login after register
            # auth.login(request, user)

            user.save()
            messages.success(request, "You are now registered and can log in")
            return redirect('login')

else:    
    return render(request, 'pages/signup.html')

【问题讨论】:

    标签: python django media


    【解决方案1】:

    把你的表单标签改成这样:

    <form class="needs-validation" novalidate autocomplete="off" 
    action="{% url 'signup' %}", method="POST" enctype="multipart/form-data">
    

    像这样将 request.FILES 添加到 profile_picture 中:

        profile_picture = request.FILES.get('inputprofile') or None
    

    比在你的创建请求中你这样做:

            else:
            if UserProfile.objects.filter(email=email).exists():
                messages.error(request, "That email is being used")
                return redirect('signup')
            else:
                # Looks Good
    
                if profile_picture != None
                    user = UserProfile.objects.create_user(profile_picture=profile_picture, name=name, email=email, 
                        password=password, highest_degree_earned=highest_degree_earned, college_name=college_name, 
                        graduation_year=graduation_year, skill_1=skill_1, skill_2=skill_2, skill_3=skill_3, skill_4=skill_4,
                        skill_5=skill_5, skill_6=skill_6, join_date=join_date)
                else:
                    user = UserProfile.objects.create_user(name=name, email=email, 
                        password=password, highest_degree_earned=highest_degree_earned, college_name=college_name, 
                        graduation_year=graduation_year, skill_1=skill_1, skill_2=skill_2, skill_3=skill_3, skill_4=skill_4,
                        skill_5=skill_5, skill_6=skill_6, join_date=join_date)
    
    

    对于默认图片尝试将其更改为:

     profile_picture = models.ImageField(upload_to='photos/profile_pictures/', default='/media/photos/User.jpg')
    

    【讨论】:

    • 我之前这样做过,之后没有上传任何内容。当我在管理区域中查看个人资料图片时,它只是在个人资料图片附近显示空白
    • 显示处理注册操作的视图
    • 我的应用程序还有另一个问题。如您所见,我为个人资料图片字段设置了默认图像,但它不起作用。我的媒体文件夹中也有图片。
    • 我在答案中添加了一个新部分,请您将我的答案标记为对您的问题正确
    • 我做了你提到的默认图片,但它只是显示空白,即当我不选择一个时,没有为个人资料图片上传任何内容。
    【解决方案2】:

    在 HTML 表单中,你需要使用。

    enctype="multipart/form-data"
    

    否则,文件不会发送到服务器。 将此标签添加到您的表单中

    <form method="post" enctype="multipart/form-data">
    ....
    </form>
    

    要在 django 部分获取文件,请在您的视图中使用 request.FILES.get('filename')

    profile_picture = request.FILES.get('inputprofile')
    

    【讨论】:

    • 谢谢。我设置的个人资料图片字段的默认图像不起作用。你能帮我吗?
    猜你喜欢
    • 2015-08-21
    • 1970-01-01
    • 2020-07-12
    • 2016-10-21
    • 1970-01-01
    • 2021-11-03
    • 1970-01-01
    • 2023-02-11
    • 1970-01-01
    相关资源
    最近更新 更多