- 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/")**
'수업(국비지원) > Django' 카테고리의 다른 글
| [Django] 회원가입, 로그아웃, 업데이트 (0) | 2023.04.27 |
|---|---|
| [Django] main페이지 생성 (0) | 2023.04.27 |
| [Django] 이미지 연동 (0) | 2023.04.27 |
| [Django] 로그인 오류 시 알람 처리 (0) | 2023.04.27 |
| [Django] 장고 템플릿 설명 (0) | 2023.04.27 |