앵귤러 쿠키
Angular 쿠키를 찾아다녔지만 Angular에서 쿠키 관리를 구현하는 방법을 찾을 수 없었습니다.AngularJS의 $cookie와 같은 쿠키를 관리할 수 있는 방법이 있습니까?
나만의 기능을 만드는 것을 마쳤습니다.
@Component({
selector: 'cookie-consent',
template: cookieconsent_html,
styles: [cookieconsent_css]
})
export class CookieConsent {
private isConsented: boolean = false;
constructor() {
this.isConsented = this.getCookie(COOKIE_CONSENT) === '1';
}
private getCookie(name: string) {
let ca: Array<string> = document.cookie.split(';');
let caLen: number = ca.length;
let cookieName = `${name}=`;
let c: string;
for (let i: number = 0; i < caLen; i += 1) {
c = ca[i].replace(/^\s+/g, '');
if (c.indexOf(cookieName) == 0) {
return c.substring(cookieName.length, c.length);
}
}
return '';
}
private deleteCookie(name) {
this.setCookie(name, '', -1);
}
private setCookie(name: string, value: string, expireDays: number, path: string = '') {
let d:Date = new Date();
d.setTime(d.getTime() + expireDays * 24 * 60 * 60 * 1000);
let expires:string = `expires=${d.toUTCString()}`;
let cpath:string = path ? `; path=${path}` : '';
document.cookie = `${name}=${value}; ${expires}${cpath}`;
}
private consent(isConsent: boolean, e: any) {
if (!isConsent) {
return this.isConsented;
} else if (isConsent) {
this.setCookie(COOKIE_CONSENT, '1', COOKIE_CONSENT_EXPIRE_DAYS);
this.isConsented = true;
e.preventDefault();
}
}
}
업데이트: angular2-cookie가 이제 더 이상 사용되지 않습니다.대신에 제 ngx-cookie를 사용해주세요.
이전 답변:
여기 Angular 1을 정확히 구현한 Angular 2-cookie가 있습니다.$cookies
서비스(및 a)removeAll()
method) 제가 만든 방법입니다.동일한 방법을 사용하고 있으며, 각 2 논리의 활자 스크립트에서만 구현됩니다.
부품에 서비스로 주입할 수 있습니다.providers
배열:
import {CookieService} from 'angular2-cookie/core';
@Component({
selector: 'my-very-cool-app',
template: '<h1>My Angular2 App with Cookies</h1>',
providers: [CookieService]
})
그런 다음 평소와 같이 구성에 정의하고 다음을 사용하기 시작합니다.
export class AppComponent {
constructor(private _cookieService:CookieService){}
getCookie(key: string){
return this._cookieService.get(key);
}
}
npm을 통해 받을 수 있습니다.
npm install angular2-cookie --save
NGX Cookie 서비스 이용
이 패키지를 설치할 때:npm install ngx-cookie-service --save
쿠키 서비스를 app.module.ts에 공급자로 추가합니다.
import { CookieService } from 'ngx-cookie-service';
@NgModule({
declarations: [ AppComponent ],
imports: [ BrowserModule, ... ],
providers: [ CookieService ],
bootstrap: [ AppComponent ]
})
그런 다음 구성 요소를 호출합니다.
import { CookieService } from 'ngx-cookie-service';
constructor( private cookieService: CookieService ) { }
ngOnInit(): void {
this.cookieService.set( 'name', 'Test Cookie' ); // To Set Cookie
this.cookieValue = this.cookieService.get('name'); // To Get Cookie
}
그거에요!
네, 여기 ng2 쿠키가 있습니다.
용도:
import { Cookie } from 'ng2-cookies/ng2-cookies';
Cookie.setCookie('cookieName', 'cookieValue');
Cookie.setCookie('cookieName', 'cookieValue', 10 /*days from now*/);
Cookie.setCookie('cookieName', 'cookieValue', 10, '/myapp/', 'mydomain.com');
let myCookie = Cookie.getCookie('cookieName');
Cookie.deleteCookie('cookieName');
Miquels Version Injuable as a service:
import { Injectable } from '@angular/core';
@Injectable()
export class CookiesService {
isConsented = false;
constructor() {}
/**
* delete cookie
* @param name
*/
public deleteCookie(name) {
this.setCookie(name, '', -1);
}
/**
* get cookie
* @param {string} name
* @returns {string}
*/
public getCookie(name: string) {
const ca: Array<string> = decodeURIComponent(document.cookie).split(';');
const caLen: number = ca.length;
const cookieName = `${name}=`;
let c: string;
for (let i = 0; i < caLen; i += 1) {
c = ca[i].replace(/^\s+/g, '');
if (c.indexOf(cookieName) === 0) {
return c.substring(cookieName.length, c.length);
}
}
return '';
}
/**
* set cookie
* @param {string} name
* @param {string} value
* @param {number} expireDays
* @param {string} path
*/
public setCookie(name: string, value: string, expireDays: number, path: string = '') {
const d: Date = new Date();
d.setTime(d.getTime() + expireDays * 24 * 60 * 60 * 1000);
const expires = `expires=${d.toUTCString()}`;
const cpath = path ? `; path=${path}` : '';
document.cookie = `${name}=${value}; ${expires}${cpath}; SameSite=Lax`;
}
/**
* consent
* @param {boolean} isConsent
* @param e
* @param {string} COOKIE
* @param {string} EXPIRE_DAYS
* @returns {boolean}
*/
public consent(isConsent: boolean, e: any, COOKIE: string, EXPIRE_DAYS: number) {
if (!isConsent) {
return this.isConsented;
} else if (isConsent) {
this.setCookie(COOKIE, '1', EXPIRE_DAYS);
this.isConsented = true;
e.preventDefault();
}
}
}
데이터를 저장하는 것도 유익합니다.sessionStorage
// Save data to sessionStorage
sessionStorage.setItem('key', 'value');
// Get saved data from sessionStorage
var data = sessionStorage.getItem('key');
// Remove saved data from sessionStorage
sessionStorage.removeItem('key');
// Remove all saved data from sessionStorage
sessionStorage.clear();
자세한 내용은 https://developer.mozilla.org/en-US/docs/Web/API/Window/sessionStorage
쿠키를 읽기 위해 나는 나에게 맞지 않는 미퀄 버전을 약간 수정했습니다.
getCookie(name: string) {
let ca: Array<string> = document.cookie.split(';');
let cookieName = name + "=";
let c: string;
for (let i: number = 0; i < ca.length; i += 1) {
if (ca[i].indexOf(name, 0) > -1) {
c = ca[i].substring(cookieName.length +1, ca[i].length);
console.log("valore cookie: " + c);
return c;
}
}
return "";
가장 간단한 쿠키 서비스, 읽기 전용 지원
import { DOCUMENT } from "@angular/common";
import { Inject, Injectable } from "@angular/core";
@Injectable({ providedIn: 'root' })
export class CookieService {
public constructor(@Inject(DOCUMENT) private document: Document) { }
public get(name: string) {
const cookies = this.document.cookie.split('; ')
for (let i = 0; i < cookies.length; i++) {
const [key, value] = cookies[i].split('=');
if (key === name) {
return decodeURIComponent(value);
}
}
return null;
}
}
언급URL : https://stackoverflow.com/questions/34298133/angular-cookies
'programing' 카테고리의 다른 글
런타임 오류 49, 잘못된 DLL 호출 규칙 (0) | 2023.11.02 |
---|---|
선형 레이아웃의 한 면에만 테두리를 그리는 방법은 무엇입니까? (0) | 2023.11.02 |
선택변수인쇄 (0) | 2023.11.02 |
MySQL: 다른 행 값으로 행을 계산하고 업데이트하시겠습니까? (0) | 2023.11.02 |
카르마를 사용하여 특정 하위 폴더 내의 파일을 제외하고 패턴과 일치하는 모든 파일을 제외하려면 어떻게 해야 합니까? (0) | 2023.11.02 |