Sociable is a full-stack web app for photo-sharing, and fostering user connections. The client side is built with React for a seamless interface, while Node.js powers the server, using MongoDB for data management. Cloudinary handles photo storage and delivery. Sociable employs JSON Web Tokens (JWT) for secure user authentication. Designed with the MVC architectural pattern, it offers a robust platform for sharing, exploring, and connecting through visual content.
-
Seamless Photo Sharing: Share your favorite moments effortlessly. Upload photos, add captions, and instantly share them with friends and followers.
-
Feed: Immerse yourself in a curated Feed. Explore a diverse range of visual stories.
-
User Profiles: Each user has a dedicated profile, showcasing their uploaded photos.
- React.js for a dynamic and responsive user interface.
- Redux for efficient state management.
- Node.js and Express.js - for server-side development.
- MongoDB - for scalable and flexible data storage.
-
JWT - (JSON Web Tokens) for secure user authentication. Cloud Storage:
-
Cloudinary - Utilizes cloud storage for reliable photo storage and retrieval.
- Node.js (v14 or higher)
- MongoDB (local or cloud instance)
-
Clone the repository:
git clone https://github.com/your-username/social-media-app.git cd social-media-app
-
Install dependencies:
cd client npm install cd ../server npm install
-
Set up environment variables: Create a
.env
file in theserver
directory and add the following:PORT=5000 MONGO_URI=your-mongodb-connection-string JWT_SECRET=your-jwt-secret CLIENT_URL=http://localhost:5173
-
Run the development servers:
- Backend:
cd server npm run dev
- Frontend:
cd client npm start
- Backend:
-
Access the app: Open your browser and navigate to
http://localhost:5173
.
root
├── frontend # Frontend code (React.js)
├── backend # Backend code (Node.js, Express.js)
└── README.md # Project documentation
Developed by Umesh, feel free to reach out.