본문 바로가기
수업(국비지원)/Django

[Django] login, join, 회윈 가입

by byeolsub 2023. 4. 27.
  • login

📌 urls.py-member 실행

# -*- coding: utf-8 -*-

"""
Created on Wed Dec 21 10:19:40 2022

@author:KITCOOP
member/urls.py
"""

from django.urls import path
from . import views

# 127.0.0.1:8000/member/login 요청시 views.py의 ligin 함수 실행
urlpatterns = [
    path("login/", views.login, name="login"),
    ]

 

📌 views.py 실행

from django.shortcuts import render

# Create your views here.
# member/views.py

# 127.0.0.1:8000/member/login 요청시 호출되는 함수
def login(request) :
    return render(request, "member/login.html")

📌 settings.py 수정

"""
Django settings for study1 project.

Generated by 'django-admin startproject' using Django 4.1.4.

For more information on this file, see
<https://docs.djangoproject.com/en/4.1/topics/settings/>

For the full list of settings and their values, see
<https://docs.djangoproject.com/en/4.1/ref/settings/>
"""

from pathlib import Path

# Build paths inside the project like this: BASE_DIR / 'subdir'.
BASE_DIR = Path(__file__).resolve().parent.parent

# Quick-start development settings - unsuitable for production
# See <https://docs.djangoproject.com/en/4.1/howto/deployment/checklist/>

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = "django-insecure-zskt0=@(+^8=+-&_+_!!3fbt=_hyw&+0!@-epor%4!vo&72@tv"

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

ALLOWED_HOSTS = []

# Application definition

INSTALLED_APPS = [
    "django.contrib.admin",
    "django.contrib.auth",
    "django.contrib.contenttypes",
    "django.contrib.sessions",
    "django.contrib.messages",
    "django.contrib.staticfiles",
    "member",
]

MIDDLEWARE = [
    "django.middleware.security.SecurityMiddleware",
    "django.contrib.sessions.middleware.SessionMiddleware",
    "django.middleware.common.CommonMiddleware",
    "django.middleware.csrf.CsrfViewMiddleware",
    "django.contrib.auth.middleware.AuthenticationMiddleware",
    "django.contrib.messages.middleware.MessageMiddleware",
    "django.middleware.clickjacking.XFrameOptionsMiddleware",
]

ROOT_URLCONF = "study1.urls"

TEMPLATES = [
    {
        "BACKEND": "django.template.backends.django.DjangoTemplates",
        "DIRS": [BASE_DIR/'templates'],
        "APP_DIRS": True,
        "OPTIONS": {
            "context_processors": [
                "django.template.context_processors.debug",
                "django.template.context_processors.request",
                "django.contrib.auth.context_processors.auth",
                "django.contrib.messages.context_processors.messages",
            ],
        },
    },
]

WSGI_APPLICATION = "study1.wsgi.application"

# Database
# <https://docs.djangoproject.com/en/4.1/ref/settings/#databases>
**'''
DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.sqlite3",
        "NAME": BASE_DIR / "db.sqlite3", 
    }
}
'''

DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.mysql",
        "NAME": 'kic',
        "USER": 'kic',
        "PASSWORD": '1234',
        "HOST": 'localhost',
        "PORT": '3307'
    }
}**

# Password validation
# <https://docs.djangoproject.com/en/4.1/ref/settings/#auth-password-validators>

AUTH_PASSWORD_VALIDATORS = [
    {
        "NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator",
    },
    {"NAME": "django.contrib.auth.password_validation.MinimumLengthValidator",},
    {"NAME": "django.contrib.auth.password_validation.CommonPasswordValidator",},
    {"NAME": "django.contrib.auth.password_validation.NumericPasswordValidator",},
]

# Internationalization
# <https://docs.djangoproject.com/en/4.1/topics/i18n/>

# LANGUAGE_CODE = "en-us"
LANGUAGE_CODE = "ko-kr"

# TIME_ZONE = "UTC"
TIME_ZONE = "Asia/Seoul"

USE_I18N = True

USE_TZ = True

# Static files (CSS, JavaScript, Images)
# <https://docs.djangoproject.com/en/4.1/howto/static-files/>

STATIC_URL = "static/"

# Default primary key field type
# <https://docs.djangoproject.com/en/4.1/ref/settings/#default-auto-field>

DEFAULT_AUTO_FIELD = "django.db.models.BigAutoField"

  • join 생성

📌 urls.py-member 내용 추가

# -*- coding: utf-8 -*-

"""
Created on Wed Dec 21 10:19:40 2022

@author:KITCOOP
member/urls.py
"""

from django.urls import path
from . import views

# 127.0.0.1:8000/member/login 요청시 views.py의 ligin 함수 실행
urlpatterns = [
    path("login/", views.login, name="login"),
    **# <http://127.0.0.1:8000/member/join>
    path('join/', views.join, name="join"),**
    ]

📌 member/views.py 내용 추가

from django.shortcuts import render

# Create your views here.
# member/views.py

# 127.0.0.1:8000/member/login 요청시 호출되는 함수
def login(request) :
    return render(request, "member/login.html")

**def join(request) :
    return render(request, "member/join.html")**

 


  • 회원가입

📌

from django.db import models

# Create your models here.
# python manage.py makemigrations 
#        => models.py 수정시 반드시 실행해야함
# python manage.py migrate
# mariadb에서 member_member 테이블 확인

class Member(models.Model) :
    id = models.CharField(max_length=20, primary_key=True)
    pass1 = models.CharField(max_length=20)
    name = models.CharField(max_length=20)
    gender = models.IntegerField(default=0)
    tel = models.CharField(max_length=20)
    email = models.CharField(max_length=20)
    picture = models.CharField(max_length=20)

# def __repr__(self) :  같은 함수    
    def __str__(self) :
        return self.id + ":" + self.name + ":" + self.pass1

📌 views.py 내용 수정

from django.shortcuts import render
**from .models import Member
from django.http import HttpResponseRedirect**

# Create your views here.
# member/views.py

# 127.0.0.1:8000/member/login 요청시 호출되는 함수
def login(request) :
    return render(request, "member/login.html")

**def join(request) :
    if request.method != "POST" :
         return render(request, "member/join.html")
    else : # post 방식.
        member = Member(id = request.POST["id"], # id 파라미터값.\\
                        pass1 = request.POST["pass"],\\
                        name = request.POST["name"],\\
                        gender = request.POST["gender"],\\
                        tel = request.POST["tel"],\\
                        email = request.POST["email"],\\
                        picture = request.POST["picture"])
        member.save() # insert 문장 실행.
        return HttpResponseRedirect("../login/")**