DEV Community

Linh Truong Cong Hong
Linh Truong Cong Hong

Posted on

5

Develop a social network with ReactJS, Spring Boot and MongoDB

Image description

I have developed a small social network web app for educational purpose and want to share this with the community. This app is built with ReactJS for frontend, Java Spring Boot for backend and MongoDB as the database.

The app tries to mimic a few functions of Twitter, including:

  • Create post with text and image
  • The number of characters in each post is limited to 200 characters
  • Like, comment and re-post a post
  • View the number of likes, comments and shares of a post
  • Comments are toggle
  • The number of character in each comment is limited to 100 characters
  • Follow, un-follow someone
  • See who are following us and follow them back
  • Check who we are following
  • View all posts of an individual
  • View our own posts
  • List all user accounts in the entire social network (due to the number of users are still small, I did not develop search user function)

Other functions:

  • Due to limited storage space, client app compresses the uploaded image to the maximum of 250px (width or height)
  • User avatar is created by hashing user id and convert that hash code into a hexagonal image
  • Authentication and authorization use JWT
  • Responsive frontend for desktop and mobile devices

Technical stack:

  • Frontend: ReactJS, Redux Toolkit, React Router, React Bootstrap
  • Backend: Java Spring Boot
  • Database: MongoDB

Hope you enjoy it and if this project is useful for you , please give me a ⭐ Github star ⭐ for my effort!

Source Code:
https://github.com/linhtch90/psn-social-network-public-source

Live Demo:
https://psn-social-network.herokuapp.com/#/

Sentry blog image

How I fixed 20 seconds of lag for every user in just 20 minutes.

Our AI agent was running 10-20 seconds slower than it should, impacting both our own developers and our early adopters. See how I used Sentry Profiling to fix it in record time.

Read more

Top comments (0)

Heroku

Simplify your DevOps and maximize your time.

Since 2007, Heroku has been the go-to platform for developers as it monitors uptime, performance, and infrastructure concerns, allowing you to focus on writing code.

Learn More

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay