Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
students
messenger
Commits
8953bd52
Commit
8953bd52
authored
Jan 02, 2021
by
우지원
Browse files
a
parent
f9311182
Changes
7
Show whitespace changes
Inline
Side-by-side
client/src/Pages/LogInPage.js
View file @
8953bd52
...
@@ -32,7 +32,7 @@ function LogIn() {
...
@@ -32,7 +32,7 @@ function LogIn() {
<
Form
.
Label
>
이메일
<
/Form.Label
>
<
Form
.
Label
>
이메일
<
/Form.Label
>
<
Form
.
Control
<
Form
.
Control
required
required
type
=
"
text
"
type
=
"
email
"
placeholder
=
"
이메일을 입력해주세요
"
/>
placeholder
=
"
이메일을 입력해주세요
"
/>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
필수
정보입니다
!
이메일을
입력해주세요
!
필수
정보입니다
!
이메일을
입력해주세요
!
...
@@ -43,18 +43,18 @@ function LogIn() {
...
@@ -43,18 +43,18 @@ function LogIn() {
<
Form
.
Label
>
비밀번호
<
/Form.Label
>
<
Form
.
Label
>
비밀번호
<
/Form.Label
>
<
Form
.
Control
<
Form
.
Control
required
required
type
=
"
text
"
type
=
"
password
"
placeholder
=
"
비밀번호를 입력해주세요
"
/>
placeholder
=
"
비밀번호를 입력해주세요
"
/>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
필수
정보입니다
!
비밀번호를
입력해주세요
!
필수
정보입니다
!
비밀번호를
입력해주세요
!
<
/Form.Control.Feedback
>
<
/Form.Control.Feedback
>
<
/Form.Group
>
<
/Form.Group
>
<
Link
to
=
"
./home
page
"
>
<
Link
to
=
"
./home
"
>
<
Button
type
=
"
submit
"
variant
=
"
outline-success
"
size
=
"
lg
"
className
=
"
mr-4
"
block
>
로그인
<
/Button
>
<
Button
type
=
"
submit
"
variant
=
"
outline-success
"
size
=
"
lg
"
className
=
"
mr-4
"
block
>
로그인
<
/Button
>
<
/Link
>
<
/Link
>
<
Link
to
=
"
./signup
page
"
>
<
Link
to
=
"
./signup
"
>
<
h6
type
=
"
button
"
className
=
"
text-right mt-2
"
style
=
{{
cursor
:
'
pointer
'
}}
>
회원가입
<
/h6
>
<
h6
type
=
"
button
"
className
=
"
text-right mt-2
"
style
=
{{
cursor
:
'
pointer
'
}}
>
회원가입
<
/h6
>
<
/Link
>
<
/Link
>
<
/div
>
<
/div
>
...
...
client/src/Pages/LoginForm.js
deleted
100644 → 0
View file @
f9311182
client/src/Pages/SignUpPage.js
View file @
8953bd52
...
@@ -16,6 +16,35 @@ function SingUp() {
...
@@ -16,6 +16,35 @@ function SingUp() {
setValidated
(
true
);
setValidated
(
true
);
};
};
// async function addUser(user) {
// await fetch(`http://localhost:3000/users`, {
// method: 'POST',
// headers: {
// 'Content-Type' : 'application/json'
// },
// body: JSON.stringify(user)
// //json 형식으로 보냄.
// })
// }
function
submitUser
()
{
const
username
=
document
.
querySelector
(
'
#username
'
)
const
nickname
=
document
.
querySelector
(
'
#nickname
'
)
const
email
=
document
.
querySelector
(
'
#email
'
)
const
password
=
document
.
querySelector
(
'
#password
'
)
const
user
=
{
username
:
username
.
value
,
nickname
:
nickname
.
value
,
email
:
email
.
value
,
password
:
password
.
value
}
console
.
log
(
user
);
}
return
(
return
(
<>
<>
<
Navbar
bg
=
"
dark
"
variant
=
"
dark
"
>
<
Navbar
bg
=
"
dark
"
variant
=
"
dark
"
>
...
@@ -35,6 +64,7 @@ function SingUp() {
...
@@ -35,6 +64,7 @@ function SingUp() {
<
Form
.
Control
<
Form
.
Control
required
required
type
=
"
text
"
type
=
"
text
"
id
=
"
username
"
placeholder
=
"
이름을 입력해주세요
"
/>
placeholder
=
"
이름을 입력해주세요
"
/>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
필수
정보입니다
!
이름을
입력해주세요
!
필수
정보입니다
!
이름을
입력해주세요
!
...
@@ -46,6 +76,7 @@ function SingUp() {
...
@@ -46,6 +76,7 @@ function SingUp() {
<
Form
.
Control
<
Form
.
Control
required
required
type
=
"
text
"
type
=
"
text
"
id
=
"
nickname
"
placeholder
=
"
별명을 입력해주세요
"
/>
placeholder
=
"
별명을 입력해주세요
"
/>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
필수
정보입니다
!
별명을
입력해주세요
!
필수
정보입니다
!
별명을
입력해주세요
!
...
@@ -56,7 +87,8 @@ function SingUp() {
...
@@ -56,7 +87,8 @@ function SingUp() {
<
Form
.
Label
>
이메일
<
/Form.Label
>
<
Form
.
Label
>
이메일
<
/Form.Label
>
<
Form
.
Control
<
Form
.
Control
required
required
type
=
"
text
"
type
=
"
email
"
id
=
"
email
"
placeholder
=
"
이메일을 입력해주세요
"
/>
placeholder
=
"
이메일을 입력해주세요
"
/>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
필수
정보입니다
!
이메일을
입력해주세요
!
필수
정보입니다
!
이메일을
입력해주세요
!
...
@@ -67,15 +99,17 @@ function SingUp() {
...
@@ -67,15 +99,17 @@ function SingUp() {
<
Form
.
Label
>
비밀번호
<
/Form.Label
>
<
Form
.
Label
>
비밀번호
<
/Form.Label
>
<
Form
.
Control
<
Form
.
Control
required
required
type
=
"
text
"
type
=
"
password
"
id
=
"
password
"
placeholder
=
"
비밀번호를 입력해주세요
"
/>
placeholder
=
"
비밀번호를 입력해주세요
"
/>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
<
Form
.
Control
.
Feedback
type
=
"
invalid
"
>
필수
정보입니다
!
비밀번호를
입력해주세요
!
필수
정보입니다
!
비밀번호를
입력해주세요
!
<
/Form.Control.Feedback
>
<
/Form.Control.Feedback
>
<
/Form.Group
>
<
/Form.Group
>
<
Link
to
=
"
./
"
>
<
Button
type
=
"
submit
"
variant
=
"
outline-success
"
size
=
"
lg
"
className
=
"
mr-4
"
block
>
가입
<
/Button
>
<
Link
to
=
"
./login
"
>
<
Button
type
=
"
submit
"
onClick
=
{{
submitUser
}}
variant
=
"
outline-success
"
size
=
"
lg
"
className
=
"
mr-4
"
block
>
가입
<
/Button
>
<
/Link
>
<
/Link
>
<
/div
>
<
/div
>
<
/Container
>
<
/Container
>
...
...
client/src/index.js
View file @
8953bd52
...
@@ -7,7 +7,6 @@ import ProfilePage from './Pages/ProfilePage';
...
@@ -7,7 +7,6 @@ import ProfilePage from './Pages/ProfilePage';
import
reportWebVitals
from
'
./reportWebVitals
'
;
import
reportWebVitals
from
'
./reportWebVitals
'
;
import
'
bootstrap/dist/css/bootstrap.min.css
'
;
import
'
bootstrap/dist/css/bootstrap.min.css
'
;
import
LogInPage
from
'
./Pages/LogInPage
'
;
import
LogInPage
from
'
./Pages/LogInPage
'
;
import
LoginForm
from
'
./Pages/LoginForm
'
;
import
{
BrowserRouter
as
Router
,
Route
,
Redirect
,
Switch
}
from
'
react-router-dom
'
;
import
{
BrowserRouter
as
Router
,
Route
,
Redirect
,
Switch
}
from
'
react-router-dom
'
;
import
Hello
from
'
./Hello
'
import
Hello
from
'
./Hello
'
import
HomePage
from
'
./Pages/HomePage
'
import
HomePage
from
'
./Pages/HomePage
'
...
...
server/controllers/user.controller.js
View file @
8953bd52
import
User
from
"
../models/User.js
"
import
User
from
"
../models/User.js
"
import
user
from
'
.../client/src/Pages/SignUpPage.js
'
import
isLength
from
'
validator/lib/isLength.js
'
import
isLength
from
'
validator/lib/isLength.js
'
import
isEmail
from
'
validator/lib/isEmail.js
'
import
isEmail
from
'
validator/lib/isEmail.js
'
//꼭 js붙여주기!!
//꼭 js붙여주기!!
//isEmail
//sign validation해야됨
//sign validation해야됨
const
signup
=
async
(
req
,
res
)
=>
{
const
signup
=
async
(
req
,
res
)
=>
{
const
{
name
,
nickname
,
email
,
password
}
=
req
.
body
const
{
username
,
nickname
,
email
,
password
}
=
req
.
body
//req.body를 구조분해하여 각각 보이게함 -> 모든정보들이 한줄에 보임
//req.body를 구조분해하여 각각 보이게함 -> 모든정보들이 한줄에 보임
console
.
log
(
name
,
nickname
,
email
,
password
)
console
.
log
(
user
name
,
nickname
,
email
,
password
)
try
{
try
{
if
(
!
isLength
(
name
,
{
min
:
3
,
max
:
10
}))
{
if
(
!
isLength
(
user
name
,
{
min
:
3
,
max
:
10
}))
{
//이범위를 벗어나면 error발생
//이범위를 벗어나면 error발생
return
res
.
status
(
422
).
send
(
'
Name must be 3-10 characters
'
)
return
res
.
status
(
422
).
send
(
'
Name must be 3-10 characters
'
)
//422 : 형식이 잘못되었다는 error발생
//422 : 형식이 잘못되었다는 error발생
...
@@ -29,7 +30,7 @@ const signup = async (req, res) => {
...
@@ -29,7 +30,7 @@ const signup = async (req, res) => {
}
}
const
newUser
=
await
new
User
({
const
newUser
=
await
new
User
({
name
,
user
name
,
nickname
,
nickname
,
email
,
email
,
password
,
password
,
...
...
server/models/User.js
View file @
8953bd52
...
@@ -8,7 +8,7 @@ const {String} = mongoose.Schema.Types
...
@@ -8,7 +8,7 @@ const {String} = mongoose.Schema.Types
//형식을 정의함.
//형식을 정의함.
const
UserSchema
=
new
mongoose
.
Schema
({
const
UserSchema
=
new
mongoose
.
Schema
({
name
:
{
user
name
:
{
type
:
String
,
type
:
String
,
required
:
true
,
required
:
true
,
},
},
...
...
server/routes/user.routes.js
View file @
8953bd52
...
@@ -4,7 +4,7 @@ import userCtrl from '../controllers/user.controller.js'
...
@@ -4,7 +4,7 @@ import userCtrl from '../controllers/user.controller.js'
const
router
=
express
.
Router
()
const
router
=
express
.
Router
()
//router의 역할 : './주소'부분을 처리하는 역할함.
//router의 역할 : './주소'부분을 처리하는 역할함.
router
.
route
(
'
/
api/users/
signup
'
)
router
.
route
(
'
/signup
'
)
.
post
(
userCtrl
.
signup
)
.
post
(
userCtrl
.
signup
)
.
get
(
userCtrl
.
hello
)
.
get
(
userCtrl
.
hello
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment