Saya menggunakan projek sudut yang dimulakan berdasarkan pelayan HTTP nodejs, url log masuk: http://localhost:9000/#/login
Url log masuk projek kejuruteraan Java: http://localhost:8060/login
Dan sekarang saya hanya mahu memanggil antara muka projek projek java pada projek sudut, dan projek java kini hanya akan menyediakan data json yang dikembalikan untuk projek sudut
Apabila masalah merentas domain berlaku semasa proses, saya menyediakan pemintas secara seragam pada projek Java dan menetapkan pengepala respons apabila permintaan baharu dipanggil:
response.setHeader("Access-Control-Allow-Origin" , "*" );
Tetapi masalah kehilangan sesi tidak diselesaikan
Maksudnya, apabila saya memanggil antara muka log masuk dalam projek sudut untuk log masuk, pelayan akan membuat sesi dan mengembalikan data json seperti maklumat pengguna dan maklumat kebenaran, serta mengembalikan jsessionid kepada klien;
Seperti yang ditunjukkan dalam gambar:
Log masuk berjaya dan lompat ke
http://localhost:9000/#/home
Tetapi apabila saya mengklik pada menu kiri pada halaman utama untuk melaksanakan antara muka lain projek java, seperti menanyakan antara muka senarai pengguna, ia telah dipintas dan kembali ke antara muka log masuk, kerana jsessionid yang sepadan tidak dapat ditemui dalam pengepala permintaan , yang bersamaan dengan pengguna semasa masih Belum log masuk
Prinsipnya ialah: setiap kali antara muka dipanggil dan permintaan baharu dikeluarkan, ia akan dinilai terlebih dahulu sama ada URL membawa jsession Jika tidak, ia akan dinilai bahawa terdapat jsession dalam kuki dalam pengepala permintaan wujud, ia akan dihantar ke latar belakang, dan latar belakang akan memperolehnya melalui jsession. Dapatkan sesi yang sepadan; walau bagaimanapun, jika jsession tidak wujud atau sesi yang sepadan tidak boleh diperolehi melalui jsession, sesi baharu akan dibuat
Saya ingin bertanya bagaimana untuk mengelakkan kehilangan sesi yang disebabkan oleh panggilan antara muka merentas domain?
Jadi belum ada penyelesaian. .
kemas kini
Saya telah menyelesaikannya. Bahagian belakang ialah Java springboot, bahagian hadapan adalah sudut, dan komunikasi json merentas domain digunakan.
Mod Cors, konfigurasikan corsfilter, kodnya adalah seperti berikut:
Konfigurasi ini harus ditemui di banyak tempat Perbezaan utama ialah dua perkara:
1. response.setHeader("Access-Control-Allow-Credentials","true"); //Sama ada kuki disokong merentas domain
2. response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));
Pertama sekali, selepas mengkonfigurasi kelayakan-benar, jika membenarkan-asal ditetapkan kepada *, ralat akan dilaporkan semasa melintasi domain, mengatakan bahawa asal tidak boleh ditetapkan kepada kad bebas * kerana bukti kelayakan dibenarkan, jadi ia juga mungkin untuk menetapkannya kepada domain mudah , kaedah penulisan ini harus mencapai kesan mana-mana domain.
Kemudian bahagian sudut juga perlu menetapkan sesuatu, sebagai contoh~
Nah, ini ialah $http.get(url, {withCredentials: true}).
Ok, itu sahaja.
Menetapkan Access-Control-Allow-Origin kepada * hanya digunakan untuk menyelesaikan masalah permintaan siaran merentas domain, atau kuki hanya boleh merentas nama domain peringkat kedua . , semasa menulis, ia boleh ditentukan untuk membenarkan akses kepada semua nama domain peringkat kedua di bawah nama domain peringkat pertama yang sama, seperti sf
Memandangkan ia adalah projek ng, anda sepatutnya hanya mempunyai satu halaman memuatkan. Hanya biarkan Java membuat pintu masuk untuk anda dan kembali ke halaman ini.
Masalahnya mungkin jika templat sudut anda perlu dimuatkan secara tidak segerak, ia juga akan merentas domain Satu penyelesaian ialah menambah asal seperti yang anda lakukan di atas, dan satu lagi ialah membungkus templat secara terus ke dalam skrip dan menambahnya langsung
Adakah penyelesaiannya?