기본 콘텐츠로 건너뛰기

Codeigniter + Vue

Codeigniter + Vue

When you need to use Vue.js(Nuxt) on codeigniter, there is no default way on codeigniter.

So I solve this problem with .htaccess file.

The main concept is just share one root folder.

And basically, this concept is for separate frontend and backend.

Codigniter for Backend. Vue.js for Frontend.

Like this.

Project |- application |- frontend (Vuejs) |- system |- web |- index.php |- composer.json |- package.json (This is nuxt package.json) |- nuxt-config.js

There is no package.json in frontend folder.

The nuxt build path is web folder.

That's all.

Using composer scripts for basic package manager.

So, Add scripts in composer.json

{ ...

"scripts": { "build": ["@preset", "@npm-generate"], "preset": ["@npm-install"], "npm-generate": "npm run generate", "npm-install": "npm install", } }

And, package.json

{ ...

"scripts": { "dev": "nuxt", "build": "nuxt build", "start": "nuxt start", "generate": "nuxt generate", "lint": "eslint --ext .js,.vue --ignore-path .gitignore .", "precommit": "npm run lint" }, }

nuxt.config.js

module.exports = { ...

router: { base: '/', }, srcDir: 'frontend/', generate: { dir: 'web', }, };

And setup rewrite rules on .htaccess

RewriteEngine On

DirectoryIndex index.htm index.html index.php

RewriteCond %{HTTP:Authorization} ^(.*) RewriteRule .* - [e=HTTP_AUTHORIZATION:%1]

RewriteCond $1 !^(index\.php|resources|robots\.txt|favicon\.ico|web/*) RewriteCond $1 ^(backend/*|api/*|setup/*) RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php?/$1 [L,QSA]

RewriteCond $1 !^(index\.php|resources|robots\.txt|favicon\.ico|web/*) RewriteCond $1 !^(backend/*|api/*|setup/*) RewriteRule ^(.*)$ web/$1 [L,QSA]

For example..

Request => Rewrite

/ => web/index.html (Vue.js) /backend/user => index.php/backend/user (Codeigniter) /api/user/11 => index.php/api/user/11 (Codeigniter) /sub/one => web/sub/one/index.html (Vue.js) /frontend/sub/one => 404 NOT FOUND /token/generate => index.php/token/generate (Codeigniter)

When deploy, Just type composer run-script build. That's All

from http://chicrock.tistory.com/187 by ccl(A) rewrite - 2020-03-06 16:54:55

댓글

이 블로그의 인기 게시물

[PHP] 코드이그니터 - 파일업로드 구현

[PHP] 코드이그니터 - 파일업로드 구현 파일 업로드 이번에 PHP 프레임워크인 코드 이그니터(Codeigniter)를 사용하여 홈페이지를 만드는데 사용한 이미지 업로드용 코드 입니다. upload 라이브러리를 사용하고 app~ 와 같은 위치에 upload 폴더를 만드고 다음 코드를 사용한다음 ajax 로 호출하여 파일을 업로드 합니다. function index() { // Upload 설정 $config['upload_path'] = './upload/'; $config[\'allowed_types\'] = 'gif|jpg|png'; $config['max_size'] = 100; // 100k $config['max_width'] = 1024; $config['max_height'] = 768; $this->load->library('upload', $config); $data = array(); if (! $this->upload->do_upload("service_image")) { $error = array('error' => $this->upload->display_errors()); } else { //$data = array('upload_data' => $this->upload->data()); $this->output->set_output("./upload/".$this->upload->data('file_name')); } } jquery 를 이용한 파일 업로드 호출 코드 function upload() { var datas, xhr; datas = new FormData(); datas.append( 'service_image', $( ...

2017년 1월 스타트업에서 구인할때 주로 원하는 개발 기술

2017년 1월 스타트업에서 구인할때 주로 원하는 개발 기술 php mysql linux android git kotlin gcm/fcm python mssql mongodb amazon aws ios objective-c swift github python c++ django python postgresql amazon aws html5/css3/javascript android java mysql python c++ c# java aws cloud-server dbms node.js postgresql redis nginx react.js hapi.js amazon aws restful-api angularJS jQuery html5/css3/javascript android firebase custom ui component restful-api asp.net c# html css javascript bootstrap angularjs node.js php mongodb redis 프론트엔드 주요 기술 javascript jquery ajax angularjs wbesocket html5/css3/javascript android ios java xcode node.js coffeescript mysql amazon ec2 amazon es3 android ios node.js php python java ios php mysql apache python android redis node.js jquery msa node.js java restful-api linux nosql golang redis nginx ...

이클립스 코드이그나이터 연동 ( eclipse codeigniter )

이클립스 코드이그나이터 연동 ( eclipse codeigniter ) https://ellislab.com/codeigniter/user-guide/installation/downloads.html 위의 사이트에서 코드이그나이터를 다운 받는다. 다운받은 압축 파일을 풀어 준다. 이클립스에서 php 프로젝트를 생성한 공간에 코드이그나이터 압축파일을 복사 붙여넣기 해준다. 위와 같은 화면이 나오면 정상적으로 연동이 된 것 입니다. from http://nahosung.tistory.com/22 by ccl(A) rewrite - 2020-03-06 16:20:55