import Places from '../models/Place.js' import cheerio from 'cheerio' import fs from 'fs' import axios from 'axios'; const searchPlace = async (req, res, next,) => { let DuplicateCheckPlace = await Places.findOne({ name: req.query.keyword }) req.places = DuplicateCheckPlace if (DuplicateCheckPlace) { console.log("11111111111111111111111Place################ 기존플레이스줄력중") } else { console.log("2222222222222222222222222222222222222222222222222222222") const url = "https://search.naver.com/search.naver?sm=tab_hty.top&where=nexearch&query=" + encodeURI(req.query.keyword) const editUrl = /(http(s)?:\/\/)([a-z0-9\w]+\.*)+[a-z0-9]{2,4}/gi const { data: html } = await axios.get(url) let $1 = cheerio.load(html); let places = {} $1('.ct_box_area').each(function (i) { places = { name: $1('.biz_name').text(), category: $1('.category').text(), address: $1('.addr').text(), img: "https://t1.daumcdn.net/thumb/R600x0/?fname=http%3A%2F%2Ft1.daumcdn.net%2Fqna%2Fimage%2F4b035cdf8372d67108f7e8d339660479dfb41bbd", times: [] } }) req.places = places } next() } const searchImg = async (req, res, next) => { console.log("d213532513212osfnlagm2214124", req.places) if (req.places.img !== "https://t1.daumcdn.net/thumb/R600x0/?fname=http%3A%2F%2Ft1.daumcdn.net%2Fqna%2Fimage%2F4b035cdf8372d67108f7e8d339660479dfb41bbd") { console.log("333333333333333333333333333IMG@@@@@@@@@@@@@@@@@@@ 기존이미지줄력중") req.places.times.push(new Date().toLocaleString()) console.log("세이브 전 111111111111111111", req.places) const newPlaces = await new Places(req.places).save() next() } else if (req.places.img === "https://t1.daumcdn.net/thumb/R600x0/?fname=http%3A%2F%2Ft1.daumcdn.net%2Fqna%2Fimage%2F4b035cdf8372d67108f7e8d339660479dfb41bbd") { const imgUrl = "https://www.google.com/search?q=" + encodeURI(req.query.keyword) + "+site:tistory.com/&sxsrf=ALeKk023Dv08KQDodRmpB5222lQuzw2Vaw:1610612821100&source=lnms&tbm=isch" axios.get(imgUrl) .then(async (response) => { console.log("4444444444444444444444444444444444444444444444444새로운 이미지 출력중") const html = response.data let name = req.query.keyword let $1 = cheerio.load(html); let images = $1('.RAyV4b').find('img').attr('src') req.places.img = images console.log("4141414141414141", req.places) //사진만 업데이트 // let Place2 = await Places.findOne({ name: req.query.keyword }) req.places.times.push(new Date().toLocaleString()) // await Places.updateOne({ name: req.query.keyword }, { img: images, times: Place2.times }) // res.send(images) console.log("세이브 전 222222222222222", req.places) const newPlaces = await new Places(req.places).save() next() }) } else { console.log("이미지 생성 오류발생!!") } } // if (DuplicateCheckImg !== "https://t1.daumcdn.net/thumb/R600x0/?fname=http%3A%2F%2Ft1.daumcdn.net%2Fqna%2Fimage%2F4b035cdf8372d67108f7e8d339660479dfb41bbd") { // console.log("333333333333333333333333333IMG@@@@@@@@@@@@@@@@@@@ 기존이미지줄력중") // } // else if (DuplicateCheckImg === "https://t1.daumcdn.net/thumb/R600x0/?fname=http%3A%2F%2Ft1.daumcdn.net%2Fqna%2Fimage%2F4b035cdf8372d67108f7e8d339660479dfb41bbd") { // console.log("4444444444444444444444444444444444444444444444444") // const imgUrl = "https://www.google.com/search?q=" + encodeURI(req.query.keyword) + "+site:tistory.com/&sxsrf=ALeKk023Dv08KQDodRmpB5222lQuzw2Vaw:1610612821100&source=lnms&tbm=isch" // axios.get(imgUrl) // .then(async (response) => { // const html = response.data // let name = req.query.keyword // let $1 = cheerio.load(html); // let images = $1('.RAyV4b').find('img').attr('src') // req.places.img = images // //사진만 업데이트 // // let Place2 = await Places.findOne({ name: req.query.keyword }) // req.places.times.push(new Date().toLocaleString()) // // await Places.updateOne({ name: req.query.keyword }, { img: images, times: Place2.times }) // // res.send(images) // console.log("세이브 전 111111111111111111", req.places) // const newPlaces = await new Places(req.places).save() // next() // }) // } else { // console.log("IMG에러") // } // req.places.times.push(new Date().toLocaleString()) // console.log("세이브 전222222222222222222222") // next() // } //맨 처음 검색하는 지역의 관광지의 경우 association을 받아올 수 없다. const searchAssociation = async (req, res) => { // let Place3 = await Places.findOne({ name: req.query.keyword }) let Place3 = req.places.address // if (!Place) { // res.send([]) // } if (!Place3) { console.log("asdfasdfasdf222222222222222222dsaf2222222222214123q5", Place3) res.send({ error: "Place.address is null" }) } else { let addresse = Place3.split(' ')[0] let AssociationsId = [] let addressPlaces = new RegExp(`${addresse}`) let responsePlaces = await Places.find({ address: addressPlaces }).sort({ updatedAt: -1 }) //몽구스나 몽고디비에 있는 sort 확인해보고 나열하기. console.log("$$$$$$$$$$$4", responsePlaces) res.send(responsePlaces) } // responsePlaces.map(Association => { // AssociationsId.push(Association._id) // }) // console.log("Associations = ", Associations) // res.send(AssociationsId) } export default { searchImg, searchPlace, searchAssociation }