DB의 특정 값이 어떤 값에 도달하면, 관리자에게 알림이 가도록 구현이 필요했다.

 

기본 명령어

crontab 리스트 확인
~] # crontab -l

crontab 삭제
~] # crontab -r

crontab 수정
~] # crontab -e

 

 

~] # crontab -e
편집보드는 Vi 편집모드로 작동.
(i명령어로 수정, esc누른 후 wq 엔터)

crontab 에 입력할 내용은
*/60 * * * * /usr/bin/php -e /var/www/html/checkdb.php
//매60분마다 실행
# 매분 /home/test.sh 실행
* * * * * /home/test.sh

# 매주 일요일 오전 2시 00분에 /home/test.sh 실행
0 2 * * 0 /home/test.sh

# 매일 오전 2시, 오후 2시에 /home/test.sh 실행
0 2,14 * * * /home/test.sh

# 매 10분마다 /home/test.sh 실행
*/10 * * * * /home/test.sh

# 매일 자정 0분부터 30분까지 /home/test.sh 실행
0-13 0 * * * /home/test.sh

 

 

출처 : https://blog.naver.com/crazytta/221244907179

'공부 > Php' 카테고리의 다른 글

[PHP] If 조건문 한줄로 축약  (0) 2023.12.29
[PHP] PC / 모바일 환경인지 체크하기  (0) 2020.01.21
트위터 OAuth Sign in 튜토리얼  (0) 2013.07.22
트위터 oauth with php  (0) 2013.07.22
php 파일 include  (0) 2013.01.11

<?php echo (조건)? "True입니다" : "False 입니다" ?>

1.  환경

 - 서버 : CentOs7 + Apache

 - 호스팅 :  iwinv 호스팅

 - 도메인 : 닷홈도메인

 - 보안인증서 : Globalsign Alpha SSL (닷홈구매)

 

2. 정리

 - 닷홈에서 SSL 보안인증서 유료로 구매하였다(1년)

 - 설치가 자동으로 된다해서 구매 후 이메일 인증까지 하였으나 안됨(당연..)
 - 서버는 타 호스팅을 이용하는것을 잠시 까먹음..

 - 고객센터 문의해서 인증서 파일을 받음

 

3. 설치

 1) 서버 특정 경로에 파일을 넣어줌 (권한 700, 루트계정만접근)

  - /경로/CertKey/  

 2) SSL 모듈 설치 

 yum -y install mod_ssl

 

mod_ssl 패키지 설치(SSL 암호화 지원 아파치 모듈)

3) ssl.conf 파일 수정

 nano /etc/httpd/conf.d/ssl.conf

 

...

<VirtualHost _default_:443>

# General setup for the virtual host, inherited from global configuration
DocumentRoot "/홈디렉토리경로"
ServerName 도메인주소:443

...
...

SSLCertificateFile /인증서경로/인증서이름.crt
SSLCertificateKeyFile /인증서경로/인증서키이름.key

...
...

 DocumentRoot와 Servername 은 httpd.conf 파일과 동일하게 해주어야함.

 

4) 짧은주소를 사용핟나뎜ㄴ httpd.conf 파일에서 AllowOverride none -> all로 수정

<Directory />
    AllowOverride All
    Require all granted
</Directory>

5) 아파치 재실행

 

 

홈페이지 제작을 할 때, 그누보드로 하는 경우가 많은데 기본 프로그램의 경로를 변경하여 1차적으로 숨기고 싶을 때가 있어서

찾아보니 생각보다 간단하다.

 

기본 그누보드 루트 경로에 있는 config.php 파일내에 변수를 수정하고 경로 폴더를 수정해주면 끝이다.

 

config.php 파일 내 94번째 정도 줄

...
...

define('G5_ADMIN_DIR',      'adm');
define('G5_BBS_DIR',        'bbs');
define('G5_CSS_DIR',        'css');
define('G5_DATA_DIR',       'data');
define('G5_EXTEND_DIR',     'extend');
define('G5_IMG_DIR',        'img');
define('G5_JS_DIR',         'js');
define('G5_LIB_DIR',        'lib');
define('G5_PLUGIN_DIR',     'plugin');
define('G5_SKIN_DIR',       'skin');
define('G5_EDITOR_DIR',     'editor');
define('G5_MOBILE_DIR',     'mobile');
define('G5_OKNAME_DIR',     'okname');

define('G5_KCPCERT_DIR',    'kcpcert');
define('G5_INICERT_DIR',     'inicert');
define('G5_LGXPAY_DIR',     'lgxpay');

define('G5_SNS_DIR',        'sns');
define('G5_SYNDI_DIR',      'syndi');
define('G5_PHPMAILER_DIR',  'PHPMailer');
define('G5_SESSION_DIR',    'session');
define('G5_THEME_DIR',      'theme');

define('G5_GROUP_DIR',      'group');
define('G5_CONTENT_DIR',    'content');


...
...

 

여기서 adm, bbs, theme 를 변경하고자 한다면

define('G5_ADMIN_DIR',      'admin');
define('G5_BBS_DIR',        'board');
define('G5_THEME_DIR',      'thm');

이런식으로 변경을 해주고, 실제 폴더 이름도 변경해주면 된다. 

1. 게시판 스킨 폴더 내에 write.skin.php 안에 하단부에 frwite_submit 함수

 function fwrite_submit(f){

...
...
...
        if (document.getElementById("char_count")) {
            if (char_min > 0 || char_max > 0) {
                var cnt = parseInt(check_byte("wr_content", "char_count"));
                if (char_min > 0 && char_min > cnt) {
                    alert("내용은 "+char_min+"글자 이상 쓰셔야 합니다.");
                    return false;
                }
                else if (char_max > 0 && char_max < cnt) {
                    alert("내용은 "+char_max+"글자 이하로 쓰셔야 합니다.");
                    return false;
                }
            }
        }
        
 ...
 ...
 여기에 코드삽입
 ...
 ...
 
        
       
<?php echo $captcha_js; // 캡챠 사용시 자바스크립트에서 입력된 캡챠를 검사함  ?>
 		// 파일을 첨부 했는지 확인
        var file_check = false;
        $(".frm_file").each(function(){
            if($(this).val()!=""){
                file_check = true;
                return false;
            }
        });
        // 파일을 첨부하지 않았다면 알림과 submit 취소
        if(!file_check){
            alert("파일을 하나 이상 첨부하세요.");
            return false;
        }

 

누보드 DB sql문을 입력하니 아래같은 에러가 발생함.

 

wr_datetime의 유효하지 못한 디폴트 값을 사용하셨습니다.

 

아래 코드를 phpmyAdmin 에서 쿼리문을 돌려준다.

ALTER TABLE `[에러나는_DB_칼럼]` CHANGE `wr_datetime` `wr_datetime` DATETIME NOT NULL;

alter table [에러나는_DB_칼럼] change wr_datetime wr_datetime datetime not null;

 

저는 g5_write_notice 쪽에서 에러가 발생해서 다음과같이 수정했습니다.

 

<style>
/* jquery datepicker 용 간단 CSS */
/* 출처 : https://sir.kr/g5_tip/16589 */

#ui-datepicker-div { background: #fff; margin: 5px 0 0 0; padding-top: 25px; box-shadow: 10px 10px 40px rgb(0 0 0 / 10%); }
#ui-datepicker-div .ui-datepicker-header { position: relative; margin-left: 20px; margin-right: 20px; }
#ui-datepicker-div .ui-datepicker-prev { position: absolute; display: inline-block; font-size: 12px; top: -23px; left: 0; }
#ui-datepicker-div .ui-datepicker-next { position: absolute; display: inline-block; font-size: 12px; top: -23px; right: 0; }
#ui-datepicker-div .ui-datepicker-title { position: relative; clear: both; margin-top: 10px; margin-bottom: 10px; display: flex; justify-content: space-between; align-items: center; }
#ui-datepicker-div .ui-datepicker-title select { height: auto; width: calc( 50% - 15px); min-width: 90px; padding: 4px 12px; border-radius: 0; }
#ui-datepicker-div .ui-datepicker-calendar { margin-left: 20px; margin-right: 20px; }
#ui-datepicker-div .ui-datepicker-calendar th,
#ui-datepicker-div .ui-datepicker-calendar td { width: 35px; height: 30px; text-align: center; line-height: 30px; }
#ui-datepicker-div .ui-datepicker-calendar th:first-child > span,
#ui-datepicker-div .ui-datepicker-calendar td:first-child > a { color: #dc3545; }
#ui-datepicker-div .ui-datepicker-calendar th:last-child > span,
#ui-datepicker-div .ui-datepicker-calendar td:last-child > a { color: #007bff; }
#ui-datepicker-div .ui-datepicker-calendar .ui-state-active { padding: 3px 6px; background: #6f42c1; color: #fff; font-weight: 600; }
#ui-datepicker-div .ui-datepicker-buttonpane { margin-top: 10px; display: flex; }
#ui-datepicker-div .ui-datepicker-buttonpane > button { flex: 1 1 50%; max-width: 50%; text-align: center; padding: .375rem; }
#ui-datepicker-div .ui-datepicker-buttonpane > button:first-child { order: 2; background: #dc3545; color: #fff; }
#ui-datepicker-div .ui-datepicker-buttonpane > button:last-child  { order: 1; }
 
</style>

그누보드는 기본적으로 Datepicker 플러그인을 포함하고 있다(최신버전기준)

 

 

게시판 스킨 작성 파일에(write파일) 

<?php
if (!defined('_GNUBOARD_')) exit; // 개별 페이지 접근 불가

include_once(G5_PLUGIN_PATH.'/jquery-ui/datepicker.php'); // 플러그인 인클루드

...

...

...

<input class="datepicker frm_input" >

상단에 인클루드 해주고, 클래스 datepicker 추가해준다.

 

그리고 최하단에 스크립트 삽입하기

<!-- 달력 시작-->
<script type="text/javascript">
//<![CDATA[
$(function(){
    $(".datepicker").datepicker({
        dateFormat: "yy-mm-dd",
        onSelect:function(dateText, inst) {
            console.log(dateText);
            console.log(inst);
        }
    });
    $(".targetFocus").click(function(){
        $($(this).data("target")).focus();
    });
});
//]]>
</script><!-- 달력 끝 -->

 

날짜 포맷 방식 : dateFormat: "yy-mm-dd"

yy-mm-dd : 2015-10-25

yy/mm/dd : 2015/10/25

yy.mm.dd : 2015.10.25

yymmdd : 20151025

 

 

유튜브 영상 게시판 및 최신글 스킨 제작 시에 

영상 링크 입력 및 해당 영상의 썸네일을 노출시켜야 할때 필요한 정보이다.

 

영상은 ID 값만 입력시키도록 하였고 

해당 ID로 영상 재생 및 썸네일까지 긁어올 수 있다. 

 

ID만 으로 썸네일 긁어올 수 있고, 해상도도 정해서 가져올 수 있다.

 

 

http://img.youtube.com/vi/동영상ID/이미지형식.jpg

http://i.ytimg.com/vi/동영상ID/이미지형식.jpg

이미지형식이 해상도를 정할 수 있다.

- 고품질 (480 x 360) : hqdefault.jpg

- 중간품질 (320 x 180) : mqdefault.jpg

- 보통품질 (120 x 90) : default.jpg

동영상 배경이미지 (480 x 360) : 0.jpg

 

 

http://kor.pe.kr/util/4/encode/

 

HTML 소스 변환기

 

kor.pe.kr

 

 

메인화면에서, 최신글 스킨으로 첨부파일을 출력하도록 했으나 '잘못된 접근' 이라는 오류가 발생..

 

세션체크와 같이 들어가는 부분이라, 세션체크도 해줘야함.

 

메인에서 불러오는 최신글 스킨 for문 안에 코드 추가했더니 해결.

 

$ss_name = "ss_view_{$bo_table}_{$list[ $i]['wr_id']}";

if (!get_session($ss_name)); set_session($ss_name, TRUE);

 

+ Recent posts