Showing
2 changed files
with
116 additions
and
96 deletions
... | @@ -2,96 +2,123 @@ import puppeteer from "puppeteer"; | ... | @@ -2,96 +2,123 @@ import puppeteer from "puppeteer"; |
2 | //use puppeteer | 2 | //use puppeteer |
3 | 3 | ||
4 | function setTimeoutPromise(ms) { | 4 | function setTimeoutPromise(ms) { |
5 | - return new Promise((resolve, reject) => { | 5 | + return new Promise((resolve, reject) => { |
6 | - setTimeout(() => resolve(), ms); | 6 | + setTimeout(() => resolve(), ms); |
7 | - }); | 7 | + }); |
8 | } | 8 | } |
9 | 9 | ||
10 | -async function loglogin(id, pw) { | 10 | +async function login(id, pw) { |
11 | - try{ | 11 | + try { |
12 | - //for visibility, headless: false | 12 | + //for visibility, headless: false |
13 | - const browser = await puppeteer.launch({headless: false, args:['--window-size=1920,1080']}); | 13 | + const browser = await puppeteer.launch({ |
14 | - | 14 | + headless: false, |
15 | - const page = await browser.newPage(); | 15 | + args: ["--window-size=1920,1080"], |
16 | - await page.setViewport({ | 16 | + }); |
17 | - width:1920, | 17 | + |
18 | - height:1080 | 18 | + const page = await browser.newPage(); |
19 | - }) | 19 | + await page.setViewport({ |
20 | - await page.goto('https://e-campus.khu.ac.kr/xn-sso/login.php?auto_login=&sso_only=&cvs_lgn=&return_url=https%3A%2F%2Fe-campus.khu.ac.kr%2Fxn-sso%2Fgw-cb.php%3Ffrom%3D%26login_type%3Dstandalone%26return_url%3Dhttps%253A%252F%252Fe-campus.khu.ac.kr%252Flogin%252Fcallback'); | 20 | + width: 1920, |
21 | - await page.type("#login_user_id", id); | 21 | + height: 1080, |
22 | - await page.type("#login_user_password", pw); | 22 | + }); |
23 | - | 23 | + await page.goto( |
24 | - //press the login button on E_Campus homepage | 24 | + "https://e-campus.khu.ac.kr/xn-sso/login.php?auto_login=&sso_only=&cvs_lgn=&return_url=https%3A%2F%2Fe-campus.khu.ac.kr%2Fxn-sso%2Fgw-cb.php%3Ffrom%3D%26login_type%3Dstandalone%26return_url%3Dhttps%253A%252F%252Fe-campus.khu.ac.kr%252Flogin%252Fcallback" |
25 | - await page.click('#form1 > div > div.login_btn > a > span'); | 25 | + ); |
26 | - await page.waitForTimeout(500); | 26 | + await page.type("#login_user_id", id); |
27 | - await setTimeoutPromise(1000); | 27 | + await page.type("#login_user_password", pw); |
28 | - | 28 | + |
29 | - //When login is failed, return [id, pw, message] -> ["", "", "Incorrect~"] | 29 | + //press the login button on E_Campus homepage |
30 | - if(page.url() === 'https://e-campus.khu.ac.kr/xn-sso/gw-cb.php?from=&login_type=standalone&return_url=https%3A%2F%2Fe-campus.khu.ac.kr%2Flogin%2Fcallback'){ | 30 | + await Promise.all([ |
31 | - return ["", "", "Incorrect user ID or password."]; | 31 | + page.click("#form1 > div > div.login_btn > a > span"), |
32 | - } | 32 | + page.waitForNavigation(), |
33 | - else { | 33 | + ]); |
34 | - // return [id, pw, `I got data { id:"${id}" pw:"${pw}" }`]; | 34 | + |
35 | - await peedGet(page); | 35 | + //When login is failed, return {err: "Incorrect~"} |
36 | - await page.waitForTimeout(3000); | 36 | + if ( |
37 | - await page.click('body > div:nth-child(9) > div.ui-dialog-titlebar.ui-widget-header.ui-corner-all.ui-helper-clearfix > button > span'); | 37 | + page.url() === |
38 | - await subjectGet(page); | 38 | + "https://e-campus.khu.ac.kr/xn-sso/gw-cb.php?from=&login_type=standalone&return_url=https%3A%2F%2Fe-campus.khu.ac.kr%2Flogin%2Fcallback" |
39 | - } | 39 | + ) { |
40 | - }catch(err){ | 40 | + return false; |
41 | - console.log(err) | 41 | + } else { |
42 | + return page; | ||
42 | } | 43 | } |
44 | + } catch (err) { | ||
45 | + console.log(err); | ||
46 | + } | ||
47 | + return result; | ||
43 | } | 48 | } |
44 | 49 | ||
45 | //function that get your peed for your Ecampus calendar | 50 | //function that get your peed for your Ecampus calendar |
46 | -async function peedGet(page) { | 51 | +async function getPeed(page) { |
47 | - await page.waitForTimeout(5000); | 52 | + console.log("getPeed"); |
48 | - // await page.goto('https://khcanvas.khu.ac.kr'); | 53 | + // await page.goto('https://khcanvas.khu.ac.kr'); |
49 | - await page.click('#visual > div > div.xn-main-login-container > div:nth-child(2) > div.xn-main-link-wrap.xn-main-lms-link-wrap > a'); | 54 | + let selector = |
50 | - await page.waitForTimeout(1000); | 55 | + "#visual > div > div.xn-main-login-container > div:nth-child(2) > div.xn-main-link-wrap.xn-main-lms-link-wrap > a"; |
51 | - await page.click('#global_nav_calendar_link > div.menu-item-icon-container > svg'); | 56 | + await page.waitForSelector(selector); |
52 | - await page.waitForTimeout(10000); | 57 | + await page.click(selector); |
53 | - await page.click('#calendar-feed > button'); | 58 | + |
54 | - let data = {}; | 59 | + selector = "#global_nav_calendar_link > div.menu-item-icon-container > svg"; |
55 | - let temp = await page.$('#calendar-feed-box-lower > a'); | 60 | + await page.waitForSelector(selector); |
56 | - data.name = await page.evaluate((data) => { | 61 | + page.click(selector); |
57 | - return data.textContent; | 62 | + |
58 | - }, temp); | 63 | + selector = "#calendar-feed > button"; |
59 | - data.link = await page.evaluate((data) => { | 64 | + await page.waitForSelector(selector); |
60 | - return data.href; | 65 | + page.click(selector); |
61 | - }, temp); | 66 | + |
62 | - | 67 | + // let data = {}; |
63 | - console.log(Promise.resolve(data)); | 68 | + // let temp = await page.$("#calendar-feed-box-lower > a"); |
64 | - return Promise.resolve(data); | 69 | + // data.name = await page.evaluate((data) => { |
70 | + // return data.textContent; | ||
71 | + // }, temp); | ||
72 | + // data.link = await page.evaluate((data) => { | ||
73 | + // return data.href; | ||
74 | + // }, temp); | ||
75 | + | ||
76 | + let temp = await page.$("#calendar-feed-box-lower > a"); | ||
77 | + const feed = await page.evaluate((data) => data.href, temp); | ||
78 | + | ||
79 | + selector = | ||
80 | + "body > div:nth-child(9) > div.ui-dialog-titlebar.ui-widget-header.ui-corner-all.ui-helper-clearfix > button > span"; | ||
81 | + await page.waitForSelector(selector, { timeout: 1000 }); | ||
82 | + await page.click(selector); | ||
83 | + | ||
84 | + return feed; | ||
65 | } | 85 | } |
66 | 86 | ||
87 | +async function getSubjects(page) { | ||
88 | + console.log("getSubjects"); | ||
89 | + await page.click( | ||
90 | + "#global_nav_courses_link > div.menu-item-icon-container > svg" | ||
91 | + ); | ||
67 | 92 | ||
68 | -async function subjectGet(page) { | 93 | + let data = []; |
69 | - await page.waitForTimeout(5000); | 94 | + let selector = |
70 | - await page.click('#global_nav_courses_link > div.menu-item-icon-container > svg') | 95 | + "#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li"; |
71 | - await page.waitForTimeout(5000); | 96 | + await page.waitForSelector(selector); |
72 | - let data= []; | 97 | + const number = await page.$$eval(selector, (data) => data.length); |
73 | - const number = await page.$$eval("#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li", (data) => data.length); | 98 | + for (let index = 0; index < number; index++) { |
74 | - for (let index = 0; index < number; index++) { | 99 | + data.push(await getOne(page, index + 1)); |
75 | - data.push(await getOne(page, index + 1)); | 100 | + } |
76 | - } | 101 | + return data; |
77 | - console.log(Promise.resolve(data)); | ||
78 | } | 102 | } |
79 | 103 | ||
80 | async function getOne(page, index) { | 104 | async function getOne(page, index) { |
81 | - let data = {}; | 105 | + let data = {}; |
82 | - let temp = await page.$("#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li:nth-child(" + index + ") > a"); | 106 | + let temp = await page.$( |
83 | - data.name = await page.evaluate((data) => { | 107 | + "#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li:nth-child(" + |
84 | - return data.textContent; | 108 | + index + |
85 | - }, temp); | 109 | + ") > a" |
86 | - data.link = await page.evaluate((data) => { | 110 | + ); |
87 | - return data.href; | 111 | + data.name = await page.evaluate((data) => { |
88 | - }, temp); | 112 | + return data.textContent; |
89 | - // data.subjectName = await page.$eval("#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li:nth-child(" + index + ") > a", (data) => data.textContent); | 113 | + }, temp); |
90 | - // data.subjectLink = await page.$eval("#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li:nth-child(" + index + ") > a", (data) => data.href); | 114 | + data.link = await page.evaluate((data) => { |
91 | - return Promise.resolve(data); | 115 | + return data.href; |
116 | + }, temp); | ||
117 | + // data.subjectName = await page.$eval("#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li:nth-child(" + index + ") > a", (data) => data.textContent); | ||
118 | + // data.subjectLink = await page.$eval("#nav-tray-portal > span > span > div > div > div > div > div > ul:nth-child(3) > li:nth-child(" + index + ") > a", (data) => data.href); | ||
119 | + return Promise.resolve(data); | ||
92 | } | 120 | } |
93 | 121 | ||
94 | - | ||
95 | // function that contact E_Campus | 122 | // function that contact E_Campus |
96 | // if your account is correct, value = Promise { | 123 | // if your account is correct, value = Promise { |
97 | // { name: '캘린더 피드를 보려면 클릭하세요.', | 124 | // { name: '캘린더 피드를 보려면 클릭하세요.', |
... | @@ -99,17 +126,5 @@ async function getOne(page, index) { | ... | @@ -99,17 +126,5 @@ async function getOne(page, index) { |
99 | // } | 126 | // } |
100 | //} | 127 | //} |
101 | // if your account is incorrect, value = [ '', '', 'Incorrect user ID or password.' ] | 128 | // if your account is incorrect, value = [ '', '', 'Incorrect user ID or password.' ] |
102 | -async function login(id, pw) { | ||
103 | - await setTimeoutPromise(1000); | ||
104 | -try { | ||
105 | - // value has the list ["","","Incorrect~"] | ||
106 | - const value = await loglogin(id, pw); | ||
107 | - console.log(value); | ||
108 | -} catch (e) { | ||
109 | - console.error(e); | ||
110 | - } | ||
111 | -} | ||
112 | - | ||
113 | -// login("2021105253", "qtw@@04271"); | ||
114 | 129 | ||
115 | -export { login }; | 130 | +export { login, getPeed, getSubjects }; | ... | ... |
1 | import express from "express"; | 1 | import express from "express"; |
2 | -import { login } from "./libs/E_Campus.js"; | 2 | +import { getPeed, getSubjects, login } from "./libs/E_Campus.js"; |
3 | import fs from "fs"; | 3 | import fs from "fs"; |
4 | 4 | ||
5 | const app = express(); | 5 | const app = express(); |
... | @@ -13,15 +13,20 @@ router.get("/", (req, res) => { | ... | @@ -13,15 +13,20 @@ router.get("/", (req, res) => { |
13 | 13 | ||
14 | app.use("/", router); | 14 | app.use("/", router); |
15 | 15 | ||
16 | -fs.readFile("server/login.pvdata", "utf8", (err, data) => { | 16 | +fs.readFile("server/libs/login.pvdata", "utf8", async (err, data) => { |
17 | if (err) { | 17 | if (err) { |
18 | console.error(err); | 18 | console.error(err); |
19 | - console.log("server/login.pvdata에 ID\\nPW를 작성"); | 19 | + console.log("server/libs/login.pvdata에 ID\\nPW를 작성"); |
20 | return; | 20 | return; |
21 | } | 21 | } |
22 | - login(...data.split("\r\n")); | 22 | + const page = await login(...data.split("\r\n")); |
23 | + if (page) { | ||
24 | + const feed = await getPeed(page); | ||
25 | + const subjects = await getSubjects(page); | ||
26 | + console.log({ feed, subjects }); | ||
23 | 27 | ||
24 | - app.listen(3001, function () { | 28 | + app.listen(3001, function () { |
25 | - console.log("listening on 3001"); | 29 | + console.log("listening on 3001"); |
26 | - }); | 30 | + }); |
31 | + } else console.log("Incorrect user ID or password."); | ||
27 | }); | 32 | }); | ... | ... |
-
Please register or login to post a comment