일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
- CTF
- 모의해킹
- lord of sql injection
- Error based sql injection
- 로그인
- 과제
- Reflected Xss
- union sql injection
- cookie 탈취
- Python
- Cross Site Request Forgery
- 웹개발
- blind sql injection
- Los
- 로그인페이지
- XSS
- lord of sqli
- csrf
- sql injection point
- 게시판 만들기
- JS
- css
- php
- file upload
- 쿠키
- sql injection
- JWT
- MySQL
- 세션
- cors
- Today
- Total
목록모의해킹/웹 개발 (25)
Almon Dev

이미 로그인과 회원가입 페이지는 완성했었으나몇 가지 고칠 점을 생각해 봤습니다.https://almon.tistory.com/9 에서 수정한 내용입니다. 로그인 mysql.php 수정 없음login_proc2.php수정 전 0) { while ($row = mysqli_fetch_array($sql_result)) { if ($id == $row['id'] && $pass == $row['password']) { $nickname = $row['nickname']; echo ""; echo ""; echo ""; echo ""; ..

오늘은 드디어 mysql을 이용해서 users.txt를 대체할 겁니다.mysql을 사용하기 위해 여기저기서 사용될db에 접속해서 sql문을 실행하는 동작을 함수로 만들어서 mysql.php에 저장했습니다. mysql.php $conn = mysqli_connect($host, $id, $password, $dbname);conn이라는 변수에 db에 접속한 mysqli 객체를 저장합니다. 실패 시에는 false가 저장됩니다. if (!$conn) { die("mysql 연결 에러 : ". mysqli_connect_error());}if (!$result) { die("쿼리문 에러 : " . mysqli_error($conn));}이 부분은 mysql 커넥션과 쿼리문의 응답이 제대로 왔는지 검사..

고민사실 4,5일 차는 어떻게 해야 할지 고민하는 시간이었습니다.글쓰기 기능을 추가하려고 보니 txt파일로 DB를 대체하는 것은점점 복잡해지는 것 같습니다폴더를 board --- ID --- Title 이런 식으로 구성하고,글의 내용을 작성시간(수정시간):글내용 이런 식으로 저장해보려고 했으나이제는 그냥 DB를 쓰는 게 더 나을 거 같다는 들어 Mysql을 사용해보고자 합니다. 우선 mysql의 비밀번호부터 설정합니다.처음 mysql을 설치하고 나면 root의 비밀번호가 설정되어있지 않습니다.이는 보안상 매우 취약하기도 하니 비밀번호를 설정해 줍니다. sudo mysql_secure_installationmysql설치 시 다운로드되는 mysql_secure_installation 스크립트를 실행합니다. ..

오늘 한 일오늘은 회원가입 기능을 추가했습니다.회원가입 페이지인 sign_up.php를 만들어서 sign_up_proc.php에 폼 데이터를 POST로 전송한 뒤users.txt에 id : password : nickname으로 추가하는 형태로 시작했습니다. login2.php Almond 로그인에 실패하셨습니다.'; } ?> 로그인 아이디 찾기 비밀번호 찾기 회원가입 아이..

과제는 끝냈다고 생각했으나 만들고 보니 추가할 점이 많이 보였습니다.오늘 추가한 점은 id : admin passwd : admin1234를 if문으로 하드코딩 하는 게 아니라users.txt라는 파일에 저장한 뒤 해당 파일을 읽어와서 로그인하는 과정을 추가했습니다.users.txtadmin:admin1234:Almond Devtest:test1234:tester' : '을 이용해서 문자열을 스플릿 하기 위해서 id:passwd:nickname으로 저장했습니다.login_proc2.php "; $user_split = explode(":", $user); // printf("id: %s pass: %s nickname: %s ", ...$user_split); ..

어제 완성하지 못했던 login_successful.php를 완성했습니다.login_successful.php Almond Dev 구독자 0명 글쓰기 마이페이지 로그아웃 html 코드는 profile-container 안에 프로필과 링크(기능)들을 나눴습니다.프로필은 이미지와 닉네임, 구독자 수링크는 글쓰기, 마이페이지, 로그아웃으로 구성했습니다.login_successful.css* { margin: 0; padding: 0; b..

과제 내용간이 로그인 페이지 만들기 (DB X) id = admin, pass = admin1234 일때 로그인 성공하는 페이지 만들기 CSS혹은 Bootstrep으로 꾸미기 EX) 네이버, 인스타그램 1. 간단하게 로그인 구현login .php form 태그로 로그인 폼을 만든 뒤에 submit 버튼을 이용해서 login_proc.php로 POST 메서드를 이용해 아이디와 패스워드를 전송한다POST와 GET 메서드의 차이 GET - URL에 파라미터로 내용이 전송됩니다. - URL은 브라우저마다 길이의 제한이 있어서 대용량의 경우 제한이 걸릴 수 있습니다. - URL은 로그에 기록되거나 브라우저 방문 기록 같은 곳에..

웹 서버는 무엇일까? 웹 서버 (Web Server)의 정의 웹 서버는 HTTP 프로토콜을 이용해 파일을 전송해 주는 간단한 서버입니다. 웹 서버의 하드웨어에는 웹사이트를 이루는 HTML, CSS, JavaScript가 저장되어 있고, 클라이언트의 요청이 있을 때마다 해당하는 파일을 전송합니다. 클라이언트 (Client)의 요청 클라이언트는 웹 브라우저의 URL을 이용해서 웹 서버에 파일을 요청합니다. URL의 구조는 이렇게 이루어져 있습니다.https://naver.com:443/index.htmlProtocol://Domain:Port/Path 그런데 브라우저의 주소창에는 그냥 192.168.0.8 이 적혀있어도 접속이 됩니다. 마찬가지로 naver.co..