TechTogetWorld

 daviduino.co.kr

techtogetworld.com

 david201207.blog.me

cafe.naver.com/3dpservicedavid


Cafe24 CDN 서버 활용하기


CAFE24에 등록을 할때  서비스명을 선택하면  기본적으로 하드용량과 트래픽 용량이 정해지게 됩니다.

웹 프로그램의 사용량이 늘어나게 되면, 용량이 점점 부족하게 됩니다.

이때 그림화일만을 따로 저장하고 사용하게 되면, 그만큼 하드용량과 트래픽 용량이 여유가 생깁니다.

이와같이 그림화일만 따로 저장할수있는 일정용량의 공간을 무료로 신청을 할수가 있는데,

이 무료공간이  CDN 입니다.


------------------------

1. CDN 신청방법

2. CDN 사용방법

------------------------


[CDN 신청방법]


1. 나의 서비스 관리 =>CDN 서비스 신청



[CDN 사용방법]

1. FTP PROGRAM (예: FILEZILLA )를 이용해서 본인의 CAFE 서버에 접속한다.

   접속 주소는  " 개인ID.CDN.CAFE24.COM "

   비번은 CAFE 개인계정과 동일함


2. 이미지 추가 태그

   아래 코드를 HTML에 코딩하시면, 해당이미지 "3DP1.JPG"화일이 로딩 됩니다.

   <img src="http://개인아이디.cdn3.cafe24.com/3DP1.JPG">  




 daviduino.co.kr

techtogetworld.com

 david201207.blog.me

cafe.naver.com/3dpservicedavid


IOT(사물인터넷) 웹 서비스 구축하기(WordPress 적용)  #3



미세먼지 data를 webserver 홈페지의 data 수치 list를  그래프로 나타내려고 합니다.

글의 순서는 아래와 같습니다.

홈페이지 위치는 " techtogetworld.com " 입니다. 

현재 미세먼지 측정장치 가동중이며, 홈페이지 방문하시면 data를 조회하실수 있습니다(메뉴위치 : 모바일은  화면 최 하단 ,  PC는 우측 상단)

---------------------------------------------------------------------------------------------------------

1. 조회구간의 측정data를 json type으로 변환하고, 변환된 data를 구글 차트로 보내서 그래프로 나타냄

  - 워드프레스에 php로 작성함

2. 워드프레스 page에 short code로 등록함.

3. 주메뉴에 등록함

4. data를 그래프로 나타낸 홈페이지 모습

5. 미세먼지 측정장치 모습

6. Next Step

  - 측정위치를 구글 지도에 나타냄

  - 측정기를 여러지역에 배치를 하게되면, 해당지역의 미세먼지상태를 알수 있습니다.

  - 여러지역의 미세먼지 상태를 홈페이지에서 모니터링이 가능하게 됩니다.


---------------------------------------------------------------------------------------------



조회구간의 측정data를 json type으로 변환하고, 변환된 data를 구글 차트로 보내서 그래프로 나타냄 ]

 1. 특기사항

    - php , html , java script 가 혼합되어 있는 코드입니다. 각각의 문법에 유의할 필요가 있습니다.

    - 저장위치는 워드프레스의 php 플러그인에 기록합니다. 후에 short 코드로 page에 등록합니다.

    - html, java는 워드프레스의 page에서 해석/수행이 가능하지만, php코드는 php만이 해석을 할수가 있습니다. 따라서 혼합된 코드를 

      php로 등록을 하면 문제없이 작동합니다.

    - 본 코딩에서 만큼은 자바스크립트를 js폴더에, php를 php위치에, html을 page에 각각 나누어서 작성을 하지 않는것이 좋겠습니다.

     별도로 코딩을 하게되면 data base 화일을 서로 주고받는데 문제가 발생합니다.

     따로따로 저장하지 마시고, 모든 코드를 하나로 합쳐서 php로 등록을 하는것이 편합니다.



 2. source code   

---------------------------------------------------------------------------------------------------

<?php

/*달력에서 조회구간을 선택하면, 날짜가 아래 변수로 입력이 됩니다*/

$id=$_POST['datepicker3'];

$id2=$_POST['datepicker4'];

 

/*미세먼지 측정data가 들어가는 data base에 접속을 합니다*/

$conn=mysqli_connect("localhost","user id",비밀번호,"db table", "db port");

$sql="

select * from (

SELECT dt_create, pm010, pm025, pm100

FROM  `finedust`

order by dt_create desc

limit 100000

)t_a

order by t_a.dt_create";

$result = mysqli_query($conn,$sql) ;


/* DB(DUST)의 TABLE(finedust)에 접속하여 측정결과를 읽어서, 조회구간에 해당되는 data만 배열에 저장합니다 */

  $rows=array();

  $flag=true;

  $table=array();

  $table['cols']=array(

  //  array('lable'=>'id' , 'type'=>'number'),

    array('lable'=>'dt_create','type'=>'string'),

    array('pm010'=>'pm010','type'=>'number'),

    array('pm025'=>'pm025','type'=>'number'),

    array('pm0100'=>'pm100','type'=>'number')

  );

  $rows=array();

  $date0 = new DateTime($id);

  $date2 = new DateTime($id2);

  while($r=mysqli_fetch_assoc($result)){

    $date1 = new DateTime($r['dt_create']);

    if ($date1>$date0 && $date1<$date2) {

      $temp=array();

      //$temp[]=array('v'=>(int) $r['id']);

      $temp[]=array('v'=>(string) $r['dt_create']);

      $temp[]=array('v'=>(int) $r['pm010']);

      $temp[]=array('v'=>(int) $r['pm025']);

      $temp[]=array('v'=>(int) $r['pm100']);

      $rows[]=array('c'=>$temp);

       }

    }

$table['rows']=$rows;


/* 배열에 저장된 data를 그래프용 코드(json)로 변환 */

$jsonTable=json_encode($table);

/* 여기부터는 자바 스크립트 입니다. jsonTable의 data를 구글 차트에 전달해서 그래프를 그리도록 합니다. */

?>


<script src="//www.google.com/jsapi"></script>

<script src="//www.gstatic.com/charts/loader.js"></script>

<script >

google.charts.load('43', {'packages':['corechart']});

google.charts.setOnLoadCallback(drawChart);

function drawChart() {

  var data = new google.visualization.DataTable(<?=$jsonTable?>);

  var options = {

  title: ' 현재시간까지의 측정결과 입니다.',

  curveType: 'function',

  legend: { position: 'bottom' }

  };

  var chart = new google.visualization.LineChart(document.getElementById('curve_chart'));

  chart.draw(data, options);

  }

</script>

<div id="curve_chart" style="width:1500px; height: 600px"></div>


------------------------------------------------------------------------------------------------------


[ 워드프레스 page에 short code로 등록함]

 - source code

 ------------------------------------------------------------------------------------------

<h5>조회구간을 선택하세요, 박스를 클릭하면 달력이 나옵니다.

조회하기 버튼 클릭하면, 구간 미세먼지 측정data를 조회합니다</h5>

<h4>[미세먼지측정결과 조회]</h4>

<form action="" method="post"><input id="datepicker3" name="datepicker3" type="text" /> ~ <input id="datepicker4" name="datepicker4" type="text" />

<input type="submit" value="조회하기" /></form>&nbsp;

[xyz-ips snippet="google-chart"]


------------------------------------------------------------------------------------------------------


[주메뉴에 등록함]

 - 등록방법

   . Page를 만드시면 하기 그림 " 페이지" 항목에 나타나게 되고, 선택하고 메뉴추가 버튼을 누르고, 위치 조정하 저장하면 됩니다.



[ data를 그래프로 나타낸 홈페이지 모습]

 1. 주메뉴에서 "미세먼지 모니터링 웹 서비스"항목 선택

 2. 달력에서 날짜 선택 : 조회 시작일, 끝나는 날짜

 

 


 3 측정결과 data 그래프

  - 주황색 : 10 마이크로 메타

  - 적색 : 2.5 마이크로 메타

  - 청색 : 1.0 마이크로 메타

 





 4 측정결과 data 그래프 2

  - 미세먼지 측정 장치를 6/6일 부터 켜 놓았습니다. 현재까지 data를 조회해 보겠습니다.




5 미세먼지 측정 장치 모습

 - 캐릭터 형태로 케이싱을 만들어 봤습니다. 개인 취향에 맞추어 제작을 하면 재미있을것 같습니다.

 - 캐릭터, 로봇, 화분,액자,인형 등...

  


 

 daviduino.co.kr

techtogetworld.com

 david201207.blog.me

cafe.naver.com/3dpservicedavid


IOT(사물인터넷) 웹 서비스 구축하기(WordPress 적용)  #2



미세먼지 data를 webserver 홈페이지에 수치list로  나타나도록 하려고 합니다.

글의 순서는 아래와 같습니다.

---------------------------------------------------------------------------------------------------------

1. 달력을 이용한  조회 구간 선택( 날짜구간 선택): 2가지 방법으로 구현가능하지민, 후자가 바람직해 보입니다.

   - 방법#1 : 플러그인을 이용한 구간 선택기 만들기

   - 방법 #2 : 자바스크립트( .js )를 직접 등록하여 만들기

     . 플러그인을 설치하면, 용량을 차지하게되고, 상대적으로 홈페이지가 무겁게 된다. 그러므로 가급적이면 워드프레스 자체기능을 최대한

       이용하고, 불가피한 경우에만  플러그인을 사용하는것이 좋을듯 하다.

2. 선택된 구간의 data를 화면에 뿌리기

3. 해결해야할 문제

   - "크롬"에서  style.css를 수정해도 수정사항이 반영되지 않는 문제 ( "IE 인터넷익스플로러"에서는 잘 적용이 됩니다.)

4. 코딩 TIPS

   

----------------------------------------------------------------------------------------------------------



[ 달력을 이용한  조회 구간 선택( 날짜구간 선택) : 플러그인 사용 ]

1. 날짜선택기(달력이용)를  워드프레스 페이지 "미세먼지"에 나타내기

 - 플러그인 설치 " WP Datepicker "

    


 - 설정=> WP Datepicker 로 들어가서, setting을 한다.

   . 아래와 같이 #date-field,calender-field  라고 입력후  save changes(우측 하단)을 클릭한다.

      


   . "미세먼지 페이지"로 가서 , 아래 청색 박스와 같이 입력을 합니다. 위에서 설정한 date-field ,calender-field를  화면에 나타내기 위한 코드입니다.  

     


    <H9> 미세먼지 DATA 조회 </H9>


    조회구간을 선택하세요, 박스를 클릭하면 달력이 나옵니다. 

    <H2>From <input type="text" id="date-field" />    TO <input type="text" class="calender-field" /> </H2>


    참고 : 측정DATA

    [xyz-ips snippet="showdata"]


-  상기 그림과 같이 모든 텍스트를 입력하고 나서, 홈페이지를 재로딩하고, 날짜 박스를 클릭하면, 달력이 나오고, 달력에서 날짜를 선택할수 있다.





[ 달력을 이용한  조회 구간 선택( 날짜구간 선택) : 자바스크립트( .js )를 직접 등록하여 만들기 1 ]

  1. 자바스크립트 소스화일 작성 : datepicker.js

    -  테마의 js 폴터에 저장한다. ==> /www/wp-content/themes/twentysixteen/js

    -  datepicker.js 소스 코드 => $대신에 아래와 같이 jquary를 사용해야 합니다.

       jQuery( document ).ready(function( $ ) {

       jQuery( "#datepicker1" ).datepicker({

       dateFormat: 'yy-mm-dd'

       });

       });

  2. datepicker.js 화일을 등록한다

    - 테마의 function.php 화일에 등록을 하면, 워드프레스에 등록이 되게 된다.

    - function 화일 하단에 등록한 코드

      function datepicker_method() {

     wp_enqueue_script( 'datepicker', get_stylesheet_directory_uri() . '/js/datepicker.js', array( 'jquery' ), '버전', 'true or false' );

      }

     add_action( 'wp_enqueue_scripts', 'datepicker_method' );



  3. header.php화일에 jquary를 선언(?) 등록할 필요는 없다, 오히려 등록하면 문제가 발생할수도 있으므로, 등록하지 않는다
    - 구글링을 하다보면, 등록을 하라는 글과  하지말라는 글이 존재한다.
    - 등록을 안해도 문제가 없는것으로 봐서, 등록을 안해도 무방함.  앞으로 등록않하기로 결정함.

  5. 워드프레스 페이지나 post에 datepicker.is 를 실행하라는 코딩을 한다.
    - 코딩 방법은 아래와 같이 코딩을 하면 된다.
       Date of Birth (DOB): <input type="text" id="datepicker1"> 
       Date of Birth (DOB): <input type="text" id="datepicker2">
  7. 결과( 워드프레스 페이지)
   




[ 달력을 이용한  조회 구간 선택( 날짜구간 선택) : 자바스크립트( .js )를 직접 등록하여 만들기 2 ]

  1. 달력2개 , 세부data type적용 code도 가능

    - 아래 code 중 dateFormat 이후 코드는 없어도 무방함

  2. 자바스크립트 소스화일 작성 : datepicker.js

    -  테마의 js 폴터에 저장한다. ==> /www/wp-content/themes/twentysixteen/js

    -  datepicker.js 소스 코드 => $대신에 아래와 같이 jquary를 사용해야 합니다.

      jQuery( document ).ready(function( $ ) {

      jQuery( "#datepicker3,#datepicker4" ).datepicker({

      dateFormat: 'yy-mm-dd',

      prevText: '이전 달',

      nextText: '다음 달',

      monthNames: ['1월','2월','3월','4월','5월','6월','7월','8월','9월','10월','11월','12월'],

      monthNamesShort: ['1월','2월','3월','4월','5월','6월','7월','8월','9월','10월','11월','12월'],

      dayNames: ['일','월','화','수','목','금','토'],

      dayNamesShort: ['일','월','화','수','목','금','토'],

      dayNamesMin: ['일','월','화','수','목','금','토'],

      showMonthAfterYear: true,

      changeMonth: true,

      changeYear: true,

      yearSuffix: '년'

      });

      });

  2. datepicker.js 화일을 등록한다

    - 테마의 function.php 화일에 등록을 하면, 워드프레스에 등록이 되게 된다.

   -  2개의 달력이 필요함으로 2개를 작성함 ( 조회날짜 시작일, 끝나는 날)

    - function 화일 하단에 등록한 코드

      function datepicker_method() {

     wp_enqueue_script( 'datepicker', get_stylesheet_directory_uri() . '/js/datepicker.js', array( 'jquery' ), '버전', 'true or false' );

      }

     add_action( 'wp_enqueue_scripts', 'datepicker_method' );


  3. header.php화일에 jquary를 선언(?) 등록할 필요는 없다, 오히려 등록하면 문제가 발생할수도 있으므로, 등록하지 않는다
    - 구글링을 하다보면, 등록을 하라는 글과  하지말라는 글이 존재한다.
    - 등록을 안해도 문제가 없는것으로 봐서, 등록을 안해도 무방함.  앞으로 등록않하기로 결정함.

  4. 워드프레스 페이지나 post에 datepicker.is 를 실행하라는 코딩을 한다.
    - 코딩 방법은 아래와 같이 코딩을 하면 된다.
       <H4> [미세먼지측정결과 조회]
       <form action="" method="post">   ==> post type으로 날짜를 날리면  서버로 들어가게 되고, 후에 $post 로 해당 날짜를 다시 불러서 사용가능함.
       <input type="text" name="datepicker3" id="datepicker3"> ~
       <input type="text" name="datepicker4" id="datepicker4">
       <input type="submit" value="조회하기">  ==> 날짜 선택후 조회하기 버튼을 누르면, 날짜가 서버로 날아가게 된다.
       </form>
       </H4>


  5. 결과( 워드프레스 페이지)
   





[ 선택된 구간의 data를 화면에 뿌리기]

 아래 코드는 플러그인(xyz php code"를 이용해서 php로 등록합니다.

 적용은 페이지화면으로 와서  [xyz-ips snippet="data-to-grahp"] 로 호출/실행시킨다.

   



1.달력에서 선택한 날짜를 datepickup 이라는 이름으로 불러와서, 변수 id에 저장한다

---------------------------------

$id=$_POST['datepicker3'];

$id2=$_POST['datepicker4'];

--------------------------------

2. database의 data를 $result변수에 문자열 형태로 할당한다.

--------------------------------------------------------------

$conn=mysqli_connect("localhost","david201207",quix0712,"david201207", "3306");

$sql="

select * from (

SELECT dt_create, pm010, pm025, pm100

FROM  `finedust`

order by dt_create desc

limit 100000

)t_a

order by t_a.dt_create";

$result = mysqli_query($conn,$sql) ;

---------------------------------------------------------------

3. $result에 할당된 측정data 문자열을 배열로 ($rows) 저장한다.

   저장하는 data는 선택된 날자구간일 경우에만 저장하고, 또한 화면에 뿌려주고,

   구간 이외의 data는 skip 한다

----------------------------------------------------------------

  $rows=array();

  $flag=true;

  $table=array();

  $table['cols']=array(

  //  array('lable'=>'id' , 'type'=>'number'),

    array('lable'=>'dt_create','type'=>'string'),

    array('pm010'=>'pm010','type'=>'number'),

    array('pm025'=>'pm025','type'=>'number'),

    array('pm0100'=>'pm100','type'=>'number')

  );

  $rows=array();

  $date0 = new DateTime($id);

  $date2 = new DateTime($id2);

  while($r=mysqli_fetch_assoc($result)){

    $date1 = new DateTime($r['dt_create']);

    if ($date1>$date0 && $date1<$date2) {

      $temp=array();

      //$temp[]=array('v'=>(int) $r['id']);

      $temp[]=array('v'=>(string) $r['dt_create']);

      $temp[]=array('v'=>(int) $r['pm010']);

      $temp[]=array('v'=>(int) $r['pm025']);

      $temp[]=array('v'=>(int) $r['pm100']);

      $rows[]=array('c'=>$temp);

      echo($r['dt_create']."__[PM1.0: ".$r['pm010']."]__[PM2.5: ".$r['pm025']."]__[PM10: ".$r['pm100']."]<br>");

      }

    }

 $table['rows']=$rows;

/* 배열에 저장된 data를 그래프용 코드(json)로 변환 */

  $jsonTable=json_encode($table);

------------------------------------------------------------------------

4. 화면에 뿌려진 측정data

  - 조회기간 : 2017.6.7~2017.6.8

  - 그래프의 필요성이 다시한번 느껴지는 순간입니다.




[코딩 TIPS]

 1. 변수값 화면 프린팅

   - PRINT로 해야할경우

      ------------------------

      $date0 = new DateTime($id);

      $date2 = new DateTime($id2);

     print $date0->format("c");

     print $date2->format("c");

      ------------------------

   - ECHO로 해야할경우

     ------------------------

     $id=$_POST['datepicker3'];

     $id2=$_POST['datepicker4'];

     echo($id);

     echo($id2);

     ------------------------

   - while() 반복문은 ()안의 조건이 참일때 반복하는 반복문입니다. 그러나 데이터 베이스에서는 데이터베이스에서 가진 모든값을 불러오길 원할경우에 

     아래와 같이 자주 사용된다.

      데이터베이스의 값을 문자열로 $result로 할당하고, 이를 배열로 만들어서(mysqli_fetch_assoc) $row(배열)에 저장하고, 이를 모두 프린팅 하는 예제입니다.

     -----------------------------------------------------------------------------------------------

     while ($row= mysqli_fetch_assoc($result)) {

     echo($row['dt_create']."__[PM1.0: ".$row['pm010']."]__[PM2.5: ".$row['pm025']."]__[PM10: ".$row['pm100']."]<br>");

     -----------------------------------------------------------------------------------------------



 daviduino.co.kr

techtogetworld.com

 david201207.blog.me

cafe.naver.com/3dpservicedavid



IOT(사물인터넷) 웹 서비스 구축하기(WordPress 적용)


워드프레스로 사물인터넷 웹서버 구축하고자 합니다.

Mot 소그룹 wemakers에서 공동프로젝트로 진행했던, 미세먼지 측정장치의 측정결과를 웹 서비스하는방법에 대해 정리해 보도록 하겠습니다.

기존에 측정결과를 

 - 집안 인터넷에 연결된 "라즈베리파이"를 서버로 구축

 - 집안 인터엣에 연결된 " 노트북 " 을 서버로 구축 하는 방법에 대해서는 이전글을 통해 소개를 한바가 있습니다.

이번글에서는

 - CAFE24에 미세먼지 측정결과 서비스 서버를 구축하고, 웹프로그래밍은 워드프레스로 하도록 하겠습니다.

 - 웹 프로그래밍을 배워가면서 처음부터 끝까지 코딩으로 직접해봤지만, 맘에드는 홈페이지를 구축하기위해선  웹프로그래밍 역량+디자인감각이 중요하다는것을 다시한번 느끼게 되었습니다.

 - 결론은 웹프로그래밍을 도와주는 TOOLS 이 필요함을 느끼게 되었고, 바람님/기획실장님이 추천해주신 워드프레스를 이용하게 되었습니다.


글의순서는 아래와 같습니다.

1.워드프레스 웹 서버 만들기

2.미세먼지 DATA를 워드프레스 data base "mysql"에 저장하기

3.next step

 - mysql에 쌓인 data를 웹에서 보여주기

 - 홈페이지에 측정data service 하기


[워드프레스 웹 서버 만들기]

1. cafe24 가입

2. 워드프레스 설치하기 : 아래 청색 박스 클릭

 


3. 플러그인 설치하기 

 - 많은 플러그인중에서 우선 망보드 를 설치했습니다.

 - 홈페이지를 구축하는데 필요한 게시판,자료실등이 사용자가 원하는 대로 조정할수있도록  플렉시블 하고, 무료입니다.

 



3. 테마 설치하기

 - 많은 유료,무료 테마가 있습니다.

 - 그중에 무료테마 Twenty sixteen 테마를 선택함(홈페이지 목적,취향에 맞는 테마)

 


3. 페이지(page) 만들기

 - 페이지를 만들어 놓고, 메뉴등에 등록해서 홈페이지에 나타낼수 있습니다.

 - 만드는 방법은

   . 새페이지 추가

   . 새페이지 내용에 망보드의 아래 타입을 복사한다. 복사를 하게되면 새 페이지가 망보드의 속성을 이어받게 된다.

     즉 자료실 타입을 복사하면, 실제로 자료를 등록,삭제등을 할수있는 기능을 가진 페이지로 변하게 된다.

   . 물론 내용에 복사하지 않으면, 공란으로 남게 되고, 이 공란에 자신이 원하는 php를 프로그래밍을 하면 된다.

   . 페이지 하나에 망보드 게시판 하나씩을 만들어야만, posting한 내용이 각각 페이지에 들어가게된다.

     그렇치 않으면 하나의 post가 중복해서 페이지에 나타나게 된다.

 - 망보드 게시판 타입

      자료실: [mb_board name="gallery" style=""]

      갤러리: [mb_board name="gallery" list_type="gallery" style=""]
      캘린더: [mb_board name="gallery" list_type="calendar" style=""]
      최근 게시물: [mb_latest name="gallery" title="gallery" list_size="5" style=""]

 - 만든 페이지 모습(갤러리, 미세먼지........)

   


4. 메뉴만들기

 - 페이지로 만들어 놓은 항목들이 , 아래 메뉴만드는 화면에 "페이지"로에 나타난다.

 - 아래 페이지에 나타난 " 전면페이지, 미세먼지....."등을 선택하고, 아래 메뉴추가 버튼을 누르면, 오른쪽 메뉴구조에 등록이 된다.

 - 메뉴설정 하단의 "기본메뉴 "를 클릭 선택한다.

 - 지금 설정한 메뉴항목들이, 홈페이지 접속시 상단 기본메뉴에 나타나게 된다

  


4. 홈페이지 외관모습

 - 워드프레스로 간단한 몇가지 메뉴를 만들어 봤습니다.

 - 나머지는 테마를 설치하면(twenty sixteen)디폴트로 등록되는 내용입니다.

 - 하기 기본적인 내용에

  . 회원관리

   - 등록,탈퇴등

  . 쇼핑몰

   - 결재, 구매,상품등록은  "우커머스 테마"등에 많은 기능이 있습니다, 실제로 신용카드 등록 결재를 할수있는 기능들 입니다.

  . 필요사진등으로 화면을 꾸미고, style화일을 편집해서 구성품등을 표현해 나갈수 있습니다.

 - 이와 같이 본인이 필요한 기능을 홈페이지에 만들기 위해 , 테마, 플로그인등을 설치하고, 설정해 나가면 됩니다.

  . 경우에 따라서는 유료테마, 플러그인을 사용하는경우도 있습니다.





[미세먼지 DATA를 워드프레스 data base "mysql"에 저장하기]


1. FIRM WARE 수정하기

 . 기존의 Nodemce의 펌웨를cafe24 서버에 맞도록 수정을 합니다.

 . firmware의 기능

   -. 미세먼지 센서가 측정한 결과를 웹서버로 전송하는 역할을 합니다.

      본 화일은 본인의 cafe24 웹서버와 thingspeak라는 시중의 측정data를 호스팅 서빙하는 홈페이지로 보내줍니다. thingspeak로의 송신은 테스트목적입니다.

 . PMS7003.h는 변동사항 없습니다.

 . firmware 수정부분

  --------------------------------------------------

   const char* khost = "techtogetworld.com";

   void karaClient(int pm1_0, int pm2_5, int pm10_0){

   const int httpPort =80;

    if (!client.connect(khost, httpPort)) {

     return;

     }

    String url = "/dust/dustdata.php";

  ------------------------------------------

  . source code

PMS7003s.h

sketch_oct30a_v03.ino



2. dustdata.php 수정하기

 - dustdata.php의 기능

  . node mcu에서 미세먼지 측정 data를 웹서버로 보내면,

  . dustdata.php에서 이 data를 받아서 cafe24의 data base에 저장을 하게됩니다.

 - dustdata.php의 수정내용

  -------------------------------------------

      $servername = "localhost";

$username = "  본인의 user name을 입력한다  "; ==> "root"가 아닌, 본인의 user name을 입력하시면 됩니다 ( mysql data base "id" )

$password = "비밀번호"; ==>mysql 비밀번호

$db_name = "db name"; ==> 하나의 계정에 하나의 db가 주어진다(cafe24 포함 거의 대다수의 호스팅 업체가 동일함) , 그  db 이름을 입력한다

      if( isset($_GET['dust1_0']) && isset($_GET['dust2_5']) && isset($_GET['dust10_0']))

       {

$d010=$_GET['dust1_0'];

$d025=$_GET['dust2_5'];

$d100=$_GET['dust10_0'];

// Create connection

$mysqli = mysqli_connect(localhost, user name, 비밀번호, db name ,db port); => 본인의 내용을 입력한다.

 - source code

 dustdata.php


3. MYSQL 서버에 저장된 미세먼저 측정결과 DATA

 - CAFE24 메뉴중에서 서비스접속관리=>MYSQL 웹어드민 항목클릭하여 MYSQL에 접속한다.

   

 

 - cafe24에서 부여한 db name 아래에 field를 구성한다.

   id, dt_create , 측정결과 3개

 

 - mysql에 저장된 미세먼지 data 모습

  . 미세먼지 측정장치를 가동시킨다.

  . 일정 시간 간격으로 data가 쌓이게 된다.  




현재까지의 홈페이지 모습은

 http://techtogetworld.com/

여기를방문하시면 보실수 있습니다.



[Next step]


 아래글은 다음 회차에 이어서 posting 하겠습니다.

 - mysql에 쌓인 data를 웹에서 보여주기

 - 홈페이지에 측정data service 하기



 daviduino.co.kr

techtogetworld.com

 david201207.blog.me

cafe.naver.com/3dpservicedavid

도메인 등록 / 호스팅 서비스 등록하기 입니다.


1. 도메인 등록 : Cafe24
2. Hosting Service 등록 : cafe24
 -aws(아마존 웹 서비스) 서비스도 있으나,요금체계및 비용문제를 좀더 검토해볼 필요가 있어보임.

[ 도메인 등록]

- 도메인 명 : techtogetworld.com
- 서버 :cafe24

[ 도메인 등록]
- 웹 호스팅 서비스 등록
- 웹 사이명 : http://techtogetworld.com/
- 서버 : cafe24

[ Wordpress 설치]
  



 daviduino.co.kr

techtogetworld.com

 david201207.blog.me

cafe.naver.com/3dpservicedavid


티스토리 블로그 주소를 개인 도메인으로 연결하기

참고한글(출처) : https://extrememanual.net/5800



[목적]

개인 홈페이지를 직접만들기는 부담스럽고, 홈페이지 운영이 필요할때 사용할수있는 방법입니다.


[개요]

티스토리는 2개의 도메인을 사용할수 있습니다.

기본도메인 : 도메인의 기본형태가 "주소.tistory.com" 의 형태입니다.

예)http://techtogetworld.tistory.com  

하지만 남들과 차별화된 도메인 주소로 운영하고 싶은 경우에는 도메인을 구매해서 티스토리 블로그에 연결을 할수가 있습니다.

가비아에서"https://domain.gabia.com/" 의 도메인을 구매했는데, 티 스토리와 연동이 편리하게 되어있습니다.

가비아 기준으로 설명드리겠습니다.


[구현방법]


가비아에 회원가입하고, 도메인 등록합니다.



네임플러스 메뉴로 들어가서

구매한 도메인 주소를 입력하고, 관리기능 선택=>블로그 연결을 선택합니다.

도메인주소앞의 www는 신경안쓰셔도 됩니다. 도메인 주소로만 연결이 됩니다.




연결설정에서 tistory를 선택합니다.




정보확인 합니다.


가비아에서 네임플러스를 이용한 도메인 설정이 끝났으면 티스토리 관리자 메뉴의 환경설정 – 기본정보에서 블로그 주소를 2차주소로 선택한 다음 구입한 도메인을 입력하면 티스토리 블로그에 도메인을 연결하는 설정이 끝납니다.