Sự khác biệt giữa JSF, Servlet và JSP là gì?

837
Cheung 2010-01-20 07:15.

Tôi có một số câu hỏi. Đó là :

  1. JSP và Servlet liên quan với nhau như thế nào?
  2. JSP có phải là một số loại Servlet không?
  3. JSP và JSF liên quan với nhau như thế nào?
  4. JSF có phải là một số loại JSP dựa trên giao diện người dùng tạo trước như ASP.NET-MVC không?

10 answers

1236
BalusC 2010-01-20 12:39.

JSP (Trang JavaServer)

JSP là một công nghệ chế độ xem Java chạy trên máy chủ cho phép bạn viết văn bản mẫu bằng các ngôn ngữ phía máy khách (như HTML, CSS, JavaScript, v.v.). JSP hỗ trợ taglibs , được hỗ trợ bởi các đoạn mã Java cho phép bạn kiểm soát luồng trang hoặc đầu ra một cách động. Một taglib nổi tiếng là JSTL . JSP cũng hỗ trợ Ngôn ngữ biểu thức , có thể được sử dụng để truy cập dữ liệu phụ trợ (thông qua các thuộc tính có sẵn trong phạm vi trang, yêu cầu, phiên và ứng dụng), chủ yếu kết hợp với taglib.

Khi JSP được yêu cầu lần đầu tiên hoặc khi ứng dụng web khởi động, vùng chứa servlet sẽ biên dịch nó thành một lớp mở rộng HttpServletvà sử dụng nó trong suốt thời gian tồn tại của ứng dụng web. Bạn có thể tìm thấy mã nguồn được tạo trong thư mục làm việc của máy chủ. Trong ví dụ Tomcat , đó là /workthư mục. Đối với một yêu cầu JSP, vùng chứa servlet sẽ thực thi lớp JSP đã biên dịch và gửi đầu ra được tạo (thường chỉ là HTML / CSS / JS) thông qua máy chủ web qua mạng tới phía máy khách, từ đó hiển thị nó trong trình duyệt web.

Servlets

Servlet là một giao diện lập trình ứng dụng Java (API) chạy trên máy chủ, giao diện này chặn các yêu cầu do máy khách thực hiện và tạo / gửi phản hồi. Một ví dụ nổi tiếng là HttpServletcung cấp các phương thức để kết nối các yêu cầu HTTP bằng cách sử dụng các phương thức HTTP phổ biến như GETPOST. Bạn có thể định cấu hình HttpServlets để lắng nghe một mẫu URL HTTP nhất định, có thể định cấu hình trong web.xmlhoặc gần đây hơn với Java EE 6 , với @WebServletchú thích.

Khi một Servlet được yêu cầu lần đầu tiên hoặc trong quá trình khởi động ứng dụng web, vùng chứa servlet sẽ tạo một phiên bản của nó và giữ nó trong bộ nhớ trong suốt thời gian tồn tại của ứng dụng web. Phiên bản tương tự sẽ được sử dụng lại cho mọi yêu cầu đến có URL khớp với mẫu URL của servlet. Bạn có thể truy cập dữ liệu yêu cầu HttpServletRequestvà xử lý phản hồi bằng cách HttpServletResponse. Cả hai đối tượng đều có sẵn dưới dạng đối số phương thức bên trong bất kỳ phương thức nào được ghi đè của HttpServlet, chẳng hạn như doGet()doPost().

JSF (JavaServer Faces)

JSF là một khung công tác MVC dựa trên thành phần được xây dựng trên Servlet API và cung cấp các thành phần thông qua taglibs có thể được sử dụng trong JSP hoặc bất kỳ công nghệ xem dựa trên Java nào khác như Khuôn mặt . Khuôn mặt phù hợp với JSF hơn nhiều so với JSP. Cụ thể, nó cung cấp khả năng tạo khuôn mẫu tuyệt vời như các thành phần tổng hợp , trong khi JSP về cơ bản chỉ cung cấp tính năng <jsp:include>tạo khuôn mẫu trong JSF, do đó bạn buộc phải tạo các thành phần tùy chỉnh với mã Java thô (hơi mờ và nhiều công việc tẻ nhạt) khi bạn muốn thay thế một nhóm thành phần lặp lại bằng một thành phần duy nhất. Kể từ JSF 2.0, JSP đã không còn được dùng nữa vì công nghệ xem có lợi cho Khuôn mặt.

Lưu ý : Bản thân JSP KHÔNG bị phản đối, chỉ là sự kết hợp của JSF với JSP không được dùng nữa.

Lưu ý : JSP có khả năng tạo mẫu tuyệt vời bằng Taglibs, đặc biệt là biến thể ( Tag File ). JSP templating kết hợp với JSF là những gì còn thiếu.

Là một khuôn khổ MVC ( Model-View-Controller ), JSF cung cấp FacesServletnhư một Bộ điều khiển phản hồi yêu cầu duy nhất . Nó đưa tất cả các yêu cầu / phản hồi HTTP tiêu chuẩn và tẻ nhạt vào tay bạn, chẳng hạn như thu thập thông tin đầu vào của người dùng, xác thực / chuyển đổi chúng, đưa chúng vào các đối tượng mô hình, gọi các hành động và hiển thị phản hồi. Bằng cách này, về cơ bản, bạn sẽ có một trang JSP hoặc Khuôn mặt (XHTML) cho Chế độ xem và một lớp JavaBean làm Mô hình . Các thành phần JSF được sử dụng để liên kết chế độ xem với mô hình (chẳng hạn như điều khiển web ASP.NET của bạn) và FacesServletsử dụng cây thành phần JSF để thực hiện tất cả công việc.

Câu hỏi liên quan

  • Phương pháp thay thế Java dòng chính cho ASP.NET / PHP là gì?
  • Phát triển web Java EE, tôi cần những kỹ năng gì?
  • Servlet hoạt động như thế nào? Thuyết minh, biến phiên và đa luồng
  • Javabean là gì và chúng được sử dụng ở đâu?
  • Làm thế nào để tránh mã Java trong tệp JSP?
  • MVC là thành phần nào trong khuôn khổ JSF MVC?
  • Sự cần thiết của JSF là gì, khi giao diện người dùng có thể đạt được với các thư viện JavaScript như jQuery và AngularJS
85
S.Lott 2010-01-20 07:28.

Xem http://www.oracle.com/technetwork/java/faq-137059.html

Công nghệ JSP là một phần của họ công nghệ Java. Các trang JSP được biên dịch thành các servlet và có thể gọi các thành phần JavaBeans (đậu) hoặc các thành phần Enterprise JavaBeans (đậu doanh nghiệp) để thực hiện xử lý trên máy chủ. Do đó, công nghệ JSP là một thành phần quan trọng trong kiến ​​trúc có khả năng mở rộng cao cho các ứng dụng dựa trên web.

Xem https://jcp.org/en/introduction/faq

Đáp: Công nghệ JavaServer Faces là một khuôn khổ để xây dựng giao diện người dùng cho các ứng dụng web. Công nghệ JavaServer Faces bao gồm:

Một tập hợp các API để: đại diện cho các thành phần giao diện người dùng và quản lý trạng thái của chúng, xử lý các sự kiện và xác thực đầu vào, xác định điều hướng trang cũng như hỗ trợ quốc tế hóa và khả năng truy cập.

Thư viện thẻ tùy chỉnh JavaServer Pages (JSP) để thể hiện giao diện JavaServer Faces trong một trang JSP.

JSP là một loại servlet chuyên biệt.

JSF là một tập hợp các thẻ bạn có thể sử dụng với JSP.

34
Vh24 2012-04-07 06:24.

Từ quan điểm Trình duyệt / Khách hàng

Cả JSP và JSF đều trông giống nhau, Theo yêu cầu của ứng dụng, JSP phù hợp hơn với các ứng dụng dựa trên yêu cầu phản hồi.

JSF được nhắm mục tiêu cho các ứng dụng Web dựa trên sự kiện phong phú hơn. Tôi thấy sự kiện chi tiết hơn nhiều so với yêu cầu / phản hồi.

Từ quan điểm máy chủ

Trang JSP được chuyển đổi thành servlet và nó chỉ có hành vi tối thiểu.

Trang JSF được chuyển đổi thành cây thành phần (bởi FacesServlet chuyên biệt) và nó tuân theo vòng đời của thành phần được xác định bởi thông số kỹ thuật.

23
Kishor Prakash 2013-07-31 20:48.

Servlet:

Java Servlet API cho phép các nhà phát triển Java viết mã phía máy chủ để cung cấp nội dung Web động. Giống như các API máy chủ Web độc quyền khác, API Java Servlet cung cấp hiệu suất được cải thiện hơn CGI; tuy nhiên, nó có một số lợi thế bổ sung chính. Bởi vì các servlet được mã hóa bằng Java, chúng cung cấp phương pháp thiết kế hướng đối tượng (OO) và quan trọng hơn là có thể chạy trên bất kỳ nền tảng nào. Do đó, cùng một mã có thể di động đến bất kỳ máy chủ nào hỗ trợ Java. Servlet đã góp phần rất lớn vào sự phổ biến của Java, vì nó đã trở thành một công nghệ được sử dụng rộng rãi để phát triển ứng dụng Web phía máy chủ.

JSP:

JSP được xây dựng dựa trên các servlet và cung cấp một giải pháp dựa trên trang, đơn giản hơn để tạo ra một lượng lớn nội dung HTML động cho các giao diện người dùng Web. JavaServer Pages cho phép các nhà phát triển và thiết kế Web chỉ cần chỉnh sửa các trang HTML bằng các thẻ đặc biệt cho các phần Java động. JavaServer Pages hoạt động bằng cách có một servlet đặc biệt được gọi là JSP container, được cài đặt trên máy chủ Web và xử lý tất cả các yêu cầu xem trang JSP. Vùng chứa JSP dịch một JSP được yêu cầu thành mã servlet, sau đó được biên dịch và thực thi ngay lập tức. Các yêu cầu tiếp theo đến cùng một trang chỉ cần gọi servlet thời gian chạy cho trang đó. Nếu một thay đổi được thực hiện đối với JSP trên máy chủ, một yêu cầu xem nó sẽ kích hoạt một bản dịch, biên dịch và khởi động lại servlet thời gian chạy khác.

JSF:

JavaServer Faces là một khuôn khổ Java tiêu chuẩn để xây dựng giao diện người dùng cho các ứng dụng Web. Quan trọng nhất, nó đơn giản hóa việc phát triển giao diện người dùng, đây thường là một trong những phần khó khăn và tẻ nhạt hơn trong quá trình phát triển ứng dụng Web.
Mặc dù có thể xây dựng giao diện người dùng bằng cách sử dụng các công nghệ Web Java nền tảng (chẳng hạn như Java servlet và JavaServer Pages) mà không cần một khung toàn diện được thiết kế để phát triển ứng dụng Web doanh nghiệp, những công nghệ cốt lõi này thường có thể dẫn đến nhiều vấn đề phát triển và bảo trì. Quan trọng hơn, vào thời điểm các nhà phát triển đạt được giải pháp chất lượng sản xuất, cùng một tập hợp các vấn đề được giải quyết bởi JSF sẽ được giải quyết theo cách không tiêu chuẩn. JavaServer Faces được thiết kế để đơn giản hóa việc phát triển giao diện người dùng cho các ứng dụng Web Java theo những cách sau:
• Nó cung cấp cách tiếp cận phát triển dựa trên thành phần, độc lập với khách hàng để xây dựng giao diện người dùng Web, do đó cải thiện năng suất của nhà phát triển và dễ sử dụng.
• Nó đơn giản hóa việc truy cập và quản lý dữ liệu ứng dụng từ giao diện người dùng Web.
• Nó tự động quản lý trạng thái giao diện người dùng giữa nhiều yêu cầu và nhiều máy khách một cách đơn giản và không phô trương.
• Nó cung cấp một khung phát triển thân thiện với các đối tượng nhà phát triển đa dạng với các bộ kỹ năng khác nhau.
• Nó mô tả một tập hợp các mẫu kiến ​​trúc tiêu chuẩn cho một ứng dụng web.

[ Nguồn: Tham khảo đầy đủ: JSF ]

18
Karthi 2013-06-20 21:59.

Cũng có những tình huống mà bạn có thể ủng hộ JSP hơn JSF. Bản chất ứng dụng phải là yếu tố quyết định để lựa chọn công nghệ.

Nếu bạn có tương tác GUI phong phú và cần nhiều tập lệnh Java thì hãy ưu tiên JSF. Về cơ bản nếu kiến ​​trúc ứng dụng GUI của bạn giống như Định hướng thành phần và thậm chí được định hướng như Swing thì JSF là tốt nhất.

Nếu ứng dụng chỉ là một biểu mẫu đơn giản đang gửi, không cần nhiều tương tác GUI, thì JSP có thể hoạt động tốt nếu việc học một công nghệ mới là một công việc tốn kém và cũng không cần thiết phải có khuôn khổ phức tạp.

13
cackle 2011-05-15 11:38.

Servlet - đó là lớp phía máy chủ java.

  • JSP - đó là Servlet với html
  • JSF - các thành phần của nó dựa trên thẻ libs
  • JSP - nó được chuyển đổi thành servlet một lần khi máy chủ nhận được yêu cầu.
10
mahesh 2011-02-23 20:21.

điều đó đúng là JSP được chuyển đổi thành servlet tại thời điểm thực thi và JSF là một thứ hoàn toàn mới để làm cho trang web dễ đọc hơn vì JSF cho phép viết tất cả các cấu trúc lập trình dưới dạng thẻ.

6
user3608245 2014-11-30 23:10.

Sự khác biệt cơ bản giữa Servlets và JSP là trong Servlets, chúng tôi viết mã java và chúng tôi nhúng mã HTML và chỉ có trường hợp ngược lại với JSP. Trong JSP, chúng tôi viết mã HTML và trong đó chúng tôi nhúng mã java bằng cách sử dụng các thẻ do JSP cung cấp.

5
Yster 2015-12-25 01:17.

Java Server Pages (JSP) là công nghệ java cho phép các nhà phát triển và thiết kế Web phát triển nhanh chóng và dễ dàng duy trì các trang Web động, giàu thông tin, tận dụng các hệ thống kinh doanh hiện có. Công nghệ JSP tách giao diện người dùng khỏi việc tạo nội dung, cho phép các nhà thiết kế thay đổi bố cục trang tổng thể mà không làm thay đổi nội dung động bên dưới.

Facelets là JSP ngôn ngữ đầu tiên không khai trang thiết kế cho JSF (Java Server Faces) mà cung cấp một mô hình lập trình đơn giản hơn và mạnh mẽ hơn để phát triển JSF như so sánh với JSP. Nó giải quyết các vấn đề khác nhau xảy ra trong JSP để phát triển ứng dụng web.

Dưới đây là bảng so sánh các tính năng của tập lệnh và khung:

Nguồn

0
Ankit 2016-07-05 01:55.
JSP:means HTML+Java Code:

JSP có vòng đời riêng của nó jsp_init () jsp_service () jsp_destroy

Sau khi yêu cầu đầu tiên, hãy chuyển đổi JSP sang tệp .java. Có ba loại thẻ mà chúng tôi đang sử dụng
1.) Không có script

<%  %>

Tại đây nhà phát triển có thể khai báo tất cả những thứ mà nhà phát triển muốn lấy dữ liệu

2.) Thẻ biểu thức

<%=  %>

Ở đây nhà phát triển có thể sử dụng một số dữ liệu liên quan đến in

3.) Tuyên bố

<!% %>

Ở đây nhà phát triển có thể khai báo một số dữ liệu liên quan đến phương pháp.

Servlet:

Servlet có vòng đời riêng của nó.

init()
service()
destroy()

Sau khi vùng chứa yêu cầu đầu tiên sẽ đọc dữ liệu từ tệp web.xml thì sau khi điền thông tin chào mừng sẽ được hiển thị.
Bây giờ trở đi sau khi thực hiện hành động, nó sẽ tìm kiếm url và sau quá trình này, nó sẽ tự tìm kiếm servlet cụ thể ở đó. hoạt động dịch vụ sẽ thực hiện.

JSF:

JSF có ui riêng và vòng đời của nó có thể hoạt động theo sáu cách,

A)Restore view phase
B)Apply request values phase
C)Process validations phase
D)Update model values phase
E)Invoke application phase
F)Render response phase

Đối với ui ở đây cho bảng ở đây chúng tôi đang sử dụng lưới bảng điều khiển và có các mặt khác nhau cho điều này.

Rich Faces
Prime Faces.

Related questions

MORE COOL STUFF

Cate Blanchett chia tay chồng sau 3 ngày bên nhau và vẫn kết hôn với anh ấy 25 năm sau

Cate Blanchett chia tay chồng sau 3 ngày bên nhau và vẫn kết hôn với anh ấy 25 năm sau

Cate Blanchett đã bất chấp những lời khuyên hẹn hò điển hình khi cô gặp chồng mình.

Tại sao Michael Sheen là một diễn viên phi lợi nhuận

Tại sao Michael Sheen là một diễn viên phi lợi nhuận

Michael Sheen là một diễn viên phi lợi nhuận nhưng chính xác thì điều đó có nghĩa là gì?

Hallmark Star Colin Egglesfield Các món ăn gây xúc động mạnh đối với người hâm mộ tại RomaDrama Live! [Loại trừ]

Hallmark Star Colin Egglesfield Các món ăn gây xúc động mạnh đối với người hâm mộ tại RomaDrama Live! [Loại trừ]

Ngôi sao của Hallmark Colin Egglesfield chia sẻ về những cuộc gặp gỡ với người hâm mộ ly kỳ tại RomaDrama Live! cộng với chương trình INSPIRE của anh ấy tại đại hội.

Tại sao bạn không thể phát trực tuyến 'chương trình truyền hình phía Bắc'

Tại sao bạn không thể phát trực tuyến 'chương trình truyền hình phía Bắc'

Bạn sẽ phải phủi sạch đầu đĩa Blu-ray hoặc DVD để xem tại sao Northern Exposure trở thành một trong những chương trình nổi tiếng nhất của thập niên 90.

Where in the World Are You? Take our GeoGuesser Quiz

Where in the World Are You? Take our GeoGuesser Quiz

The world is a huge place, yet some GeoGuessr players know locations in mere seconds. Are you one of GeoGuessr's gifted elite? Take our quiz to find out!

8 công dụng tuyệt vời của Baking Soda và Giấm

8 công dụng tuyệt vời của Baking Soda và Giấm

Bạn biết đấy, hai sản phẩm này là nguồn điện để làm sạch, riêng chúng. Nhưng cùng với nhau, chúng có một loạt công dụng hoàn toàn khác.

Hạn hán, biến đổi khí hậu đe dọa tương lai của thủy điện Hoa Kỳ

Hạn hán, biến đổi khí hậu đe dọa tương lai của thủy điện Hoa Kỳ

Thủy điện rất cần thiết cho lưới điện của Hoa Kỳ, nhưng nó chỉ tạo ra năng lượng khi có nước di chuyển. Bao nhiêu nhà máy thủy điện có thể gặp nguy hiểm khi các hồ và sông cạn kiệt?

Quyên góp tóc của bạn để giúp giữ nước sạch của chúng tôi

Quyên góp tóc của bạn để giúp giữ nước sạch của chúng tôi

Tóc tỉa từ các tiệm và các khoản quyên góp cá nhân có thể được tái sử dụng như những tấm thảm thấm dầu và giúp bảo vệ môi trường.

Tận dụng lợi thế của việc bán hàng nhân Ngày của Cha này

Tận dụng lợi thế của việc bán hàng nhân Ngày của Cha này

Màn hình Samsung Galaxy S9 Plus. Chủ nhật này là Ngày của Cha⁠ — trong trường hợp nó khiến bạn suy nghĩ — và thay vì mua cho anh ấy một chiếc cà vạt trong năm nay, có lẽ đã đến lúc bạn mua cho anh ấy thứ mà anh ấy sẽ thực sự sử dụng.

Assassin's Creed Snuck Into Monster Hunter: World Last Night

Assassin's Creed Snuck Into Monster Hunter: World Last Night

Monster Hunter: World yêu thích các sự kiện chéo. Dù có nghĩa là hóa trang thành Dante của Devil May Cry, giả dạng Horizon: Zero Dawn's Aloy, hay chiến đấu với quái vật Final Fantasy, các nhiệm vụ sự kiện khác nhau của Thế giới được nâng cấp tự do so với các trò chơi khác.

Ava DuVernay Có Quà Tặng Ngày Của Mẹ cho Tất Cả Chúng Ta: Nếp Nhăn Thời Gian Sẽ Được Viết Lại Vào Cuối Tuần Ngày Của Mẹ!

Ava DuVernay Có Quà Tặng Ngày Của Mẹ cho Tất Cả Chúng Ta: Nếp Nhăn Thời Gian Sẽ Được Viết Lại Vào Cuối Tuần Ngày Của Mẹ!

Storm Reid, Oprah Winfrey, Mindy Kaling, Reese Witherspoon và Ava DuVernay tại buổi chiếu đặc biệt của A Wrinkle in Time tại Nhà hát Walter Reade ở Thành phố New York vào ngày 7 tháng 3 năm 2018 “Ava rất mong được nói chuyện với bạn,” một trong những người của Array dư luận viên nói qua điện thoại. (Array là tập thể phân phối, nghệ thuật và vận động chính sách của Ava DuVernay tập trung vào các bộ phim của người da màu và phụ nữ.

Nhiệm vụ bất khả thi 5 sẽ khôi phục niềm tin của bạn trong phim hành động Tentpole

Nhiệm vụ bất khả thi 5 sẽ khôi phục niềm tin của bạn trong phim hành động Tentpole

Mission Impossible: Rogue Nation bắt đầu ở một cấp độ khác. Theo nghĩa đen.

Edwin McCain ra mắt Grand Ole Opry: Quay cảnh hậu trường với nhạc sĩ 'I'll Be'

Edwin McCain ra mắt Grand Ole Opry: Quay cảnh hậu trường với nhạc sĩ 'I'll Be'

McCain, người đang làm việc cho một album mới, lần đầu tiên bước vào vòng kết nối vào tối thứ Sáu ở Nashville

Nicky Hilton Forced to Borrow Paris' 'I Love Paris' Sweatshirt After 'Airline Loses All [My] Luggage'

Nicky Hilton Forced to Borrow Paris' 'I Love Paris' Sweatshirt After 'Airline Loses All [My] Luggage'

Nicky Hilton Rothschild's luggage got lost, but luckily she has an incredible closet to shop: Sister Paris Hilton's!

Kate Middleton dành một ngày bên bờ nước ở London, cùng với Jennifer Lopez, Julianne Hough và hơn thế nữa

Kate Middleton dành một ngày bên bờ nước ở London, cùng với Jennifer Lopez, Julianne Hough và hơn thế nữa

Kate Middleton dành một ngày bên bờ nước ở London, cùng với Jennifer Lopez, Julianne Hough và hơn thế nữa. Từ Hollywood đến New York và mọi nơi ở giữa, hãy xem các ngôi sao yêu thích của bạn đang làm gì!

17 tuổi bị đâm chết trong khi 4 người khác bị thương trong một cuộc tấn công bằng dao trên sông Wisconsin

17 tuổi bị đâm chết trong khi 4 người khác bị thương trong một cuộc tấn công bằng dao trên sông Wisconsin

Các nhà điều tra đang xem xét liệu nhóm và nghi phạm có biết nhau trước vụ tấn công hay không

Tôi viết như thế nào

Tôi viết như thế nào

Đối với tôi, mọi thứ là về dòng đầu tiên đó và nó sẽ đưa bạn đến đâu. Một số nhà văn bị điều khiển bởi cốt truyện, sự sắp xếp tinh tế của các quân cờ, trong khi những người khác bị lôi cuốn bởi một nhân vật và khả năng thực hiện một cuộc hành trình với một người bạn hư cấu mới.

Đường băng hạ cánh

Đường băng hạ cánh

Cuối hè đầu thu là mùa hoài niệm. Những chiếc đèn đường chiếu ánh sáng của chúng qua những con đường đẫm mưa, và những chiếc lá dưới chân - màu đỏ cam tắt trong bóng chạng vạng - là lời nhắc nhở về những ngày đã qua.

Hãy tưởng tượng tạo ra một chiến lược nội dung thực sự CHUYỂN ĐỔI. Nó có thể.

Hãy tưởng tượng tạo ra một chiến lược nội dung thực sự CHUYỂN ĐỔI. Nó có thể.

Vào năm 2021, tôi khuyến khích bạn suy nghĩ lại mọi thứ bạn biết về khách hàng mà bạn phục vụ và những câu chuyện bạn kể cho họ. Lùi lại.

Sự mất mát của voi ma mút đã mở ra trái tim tôi để yêu

Sự mất mát của voi ma mút đã mở ra trái tim tôi để yêu

Vào ngày sinh nhật thứ 9 của Felix The Cat, tôi nhớ về một trong những mất mát lớn nhất trong cuộc đời trưởng thành của tôi - Sophie của tôi vào năm 2013. Tôi đã viết bài luận này và chia sẻ nó trên nền tảng này một thời gian ngắn vào năm 2013.

Language