rest.go 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. package service
  2. import (
  3. "crawler/config"
  4. "fmt"
  5. "io"
  6. "log"
  7. "net/http"
  8. "os"
  9. "time"
  10. )
  11. type Rest struct{}
  12. // REST API 호출
  13. func (this *Rest) CallRestGetAPI(url string) ([]byte, error) {
  14. // API 호출
  15. req, err := http.NewRequest("GET", url, nil)
  16. if this.Check(err) {
  17. return nil, err
  18. }
  19. // 웹 수집을 위한 Crawler Header 값 추가
  20. req.Header.Set("Accept", "application/json")
  21. req.Header.Add("User-Agent", "Crawler")
  22. client := &http.Client{
  23. Timeout: 8 * time.Second,
  24. }
  25. res, err := client.Do(req)
  26. if this.Check(err) {
  27. return nil, err
  28. }
  29. defer func(body io.ReadCloser) {
  30. this.Check(body.Close())
  31. }(res.Body)
  32. data, err := io.ReadAll(res.Body)
  33. if this.Check(err) {
  34. return nil, err
  35. }
  36. return data, nil
  37. }
  38. func (this *Rest) CallRestGet(url string) ([]byte, error) {
  39. // API 호출
  40. req, err := http.NewRequest("GET", url, nil)
  41. if this.Check(err) {
  42. return nil, err
  43. }
  44. // 웹 수집을 위한 Crawler Header 값 추가
  45. req.Header.Add("User-Agent", "Crawler")
  46. client := &http.Client{
  47. Timeout: 8 * time.Second,
  48. }
  49. res, err := client.Do(req)
  50. if this.Check(err) {
  51. return nil, err
  52. }
  53. defer func(body io.ReadCloser) {
  54. this.Check(body.Close())
  55. }(res.Body)
  56. data, err := io.ReadAll(res.Body)
  57. if this.Check(err) {
  58. return nil, err
  59. }
  60. return data, nil
  61. }
  62. // REST API 오류 확인
  63. func (this *Rest) Check(err error) bool {
  64. if err != nil {
  65. this.WriteLog(err.Error())
  66. return true
  67. }
  68. return false
  69. }
  70. // Kobis 오류 기록
  71. func (this *Rest) WriteLog(msg string) {
  72. data, err := os.OpenFile(config.ERROR_LOG_PATH_KOBIS, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0666)
  73. if err != nil {
  74. log.Fatalln(err)
  75. }
  76. defer func() {
  77. if data.Close() != nil {
  78. fmt.Println(err)
  79. }
  80. }()
  81. log.SetOutput(data)
  82. log.Println(err)
  83. }